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| SECTION 1 
GENERAL DESCRIPTION 


1.0 INTRODUCTION. 

This manual provides operating and maintenance instructions 

for the AM-100 Central Processor Unit (CPU) circuit board 

set manufactured by Alpha Microsystems located in Irvine, 
California. Circuit board description, operating and usage 
instructions, programming, theory of operation, and maintenance 
instructions are included to provide the user with the infor- 
mation necessary to utilize this circuit board to its full 


capability. 


1.1 CIRCUIT BOARD DESCRIPTION. 

The AM-100 CPU circuit board set is a 16-bit microprocessor 
board set that is compatible with the S-100 Bus structure. 

The AM-100 utilizes the Western Digital. WD16 chip set 
microprogrammed to enhance the software of the operating 

system. The microprocessor provides 16-bit flexibility and 
speed with floating point arithmetic to provide large throughput. 
The two board AM-100 supports most of the standard S-100 Bus 


peripherals including static memory, I/O facilities and video. 


A simplified block diagram of the AM-100 CPU board set is 
shown in Figure 1-1. For a complete detailed description 


of CPU operation, see Section 4 of this manual. 


1.2 APPLICATION. 

The AM-100 is a 16-bit CPU that is fully compatible with a 
standard 8-bit S-100 bus system. It is fully compatible with 
many available peripherals from other manufacturers. A block 
diagram of the system capability is contained in Figure 1-2. 
This shows the basic S-100 Bus structure, the currently avail- 
able Alpha Micro circuit cards, and the commercially available 
peripherals that can be used for a fully integrated system. 
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SECTION 2 
OPERATING DATA 


2.0 INTRODUCTION. 

This Section contains information on the use of the AM-100 
CPU two board set. Capabilities, specifications, interface 
Wiring and user option descriptions are provided for the 


successful integration of the board into the user's system. 


2.1 CAPABILITIES AND SPECIFICATIONS. 
This two board set operates from the standard S-100 Bus 
structure and can be integrated, into a complete system. 


Specifications for the AM-100 are contained in Table 2-1. 


Table 2-1. AM-100 Specifications 


PARAMETER SPECIFICATION 


Interface type Standard S-100 Bus, 16-Bit words, 
byte multiplexed for compatibility 


to 8-bit peripherals and memories. 


Instruction Set Over 150 standard instructions coded 
in unique microcode executed on the 
WD-16 CPU chip set. 


Arithmetic Hardware floating point arithmetic 


Operations to 11 significant digits. 


CPU Architecture Microprogrammed instruction set; 
eight 16-bit general purpose regis- 
ters; floating point hardware unit; 
special high-speed byte multiplexing 


Logic. 


Table 2-1 (Cont.). AM-100 Specifications 


PARAMETER SPECIFICATION | 


Interrupt Capability] Eight vectored and one non-vectored 


interrupt lines. 


DMA Capability Seven DMA channels. (Included in vec- 
tored interrupt line count.) 
Real Time Clock Standard Feature. 


Circuit Boards Two board set - standard 5'' x 10" 


with 100-pin connectors. 


2.2 INTERFACE DESCRIPTION AND WIRING. 
The AM-100 CPU interfaces with the standard S-100 Bus 


structure. All data inputs, outputs, and control signals 


are transferred through these lines. The S-100 bus con- 
nections are made by the bottom edge connectors and are 
listed in Table 2-2. | 


Table 2-2. AM-100 Interface Signals 


SIGNAL NAME J1 
PIN NO. 

Address 0 

Address 1 

Address 2 

Address 3 

Address 4 

Address 5 

Address 6 

Address 7 

Address 8 

Address 9 

Address 10 

Address 11 

Address 12 

Address 13 

Address .14 

Address 15 
DIO Data Input Bus 95 
DI1 Bits 0-7 94 
DI2 | 41 
DI3 42 
DI4 91 
DI5 92 
DI6 93 
DI7 | 43 


Table 2-2 (Cont.). AM-100 Interface Signals 


SIGNAL | NAME Jl 
PIN NO. 


DMAGRO 
DMAGR1 
DMAGR2 
DMAGR3 


DMA Grant 


DMAGR4 
DMAGRS 
DMAGR6 
DMAGR7 


DARCY | DMA Received 


Data Out Bus 
Bits 0-7 


Not Used 18 
: 19 
22 


| PDBIN, Data busin Bus In 


PHLDA P-Hold Acknowledge 26 


2-4 
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DMA Request EVI 
CPU Interrupt Enable 
Power On Clear 
Processor Ready 
Preset 
Processor sync 

— CPU Wait 
Write Strobe 
I/O Input Cycle 
Interrupt Acknowledge 
Memory Read Cycle 
Bus Master OP Code Fetch 
I/O Output Cycle 


Bus Master Output 


sage) 


AM-100 Interface Signals 


Cy 
jd 


PIN NO. 


“J 


—S “SJ ie) 


—sS 


iw 


> ae aa DO ™ 
aon => ~] On “I “NJ ON wm NO (ee) += 


oe) 
“Nl 


Table 2-2 (Cont.). AM-100 Interface Signals 


| SIGNAL 


Vectored Interrupt 


Vectored Interrupt 


Vectored Interrupt 


Vectored Interrupt 


Vectored Interrupt 


Vectored Interrupt 


0 
1 
2 
3 
Vectored Interrupt 4 
5 
6 
7 


Vectored Interrupt 


| STVAL Status and Address Valid 
XRDY External Ready 
fm Pe Phase 2 Clock 


2.3 USER OPTIONS. 
Most of the optional capabilities of the AM-100 CPU are 


exercised with software, and an overview of the available 


famed 
bd 


software capability is contained in Section 3. The hardware 
option that must be implemented is for the bootstrap Loader 
program and determines which peripheral the boot loader is 


accessed from. 


The boot loader may be accessed from either the AM-200 circuit 
board (floppy disk controller), the AM- 500 (hard disk con- 
troller) or the AM-400 (hard disk interface). Header U3 
Selects the base address for the boot program by the jumper 
wires as shown in Figure 2-1. 


CPU1 Header U3 


1 16 1 
‘en ; 
4 113 4 
5 12 5 
| L_Hi: 
8 —1 9 g 
AM-200 Floppy Disk AM-500 (Hawk) Hard Disk 
or 


AM-400 Trident Disk 


Figure 2-1. Header Jumper Wiring 


Header U3 on CPU1 can be jumpered for other non-standard jump 
addresses. The address lines that are jumper selectable are 
A8-A13 with Al14 and A15 always high (1). 


To select an address, pins 3, 4, 5, 6, 7 and 8 can be jumpered 
to ground or left open to generate the desired code. An open 
(no jumper) selects a one for that address bit and a jumper 


to pin 14 selects a zero. 


NOTE 
Pins 9, 10, 11, 12, 13 and 14 on header 


U3 must always be connected together. 


The pins on header that correspond to the various address bits 


are as follows: 


Address line Pin on U3 

8 5 

9 4 
10 7 
11 3 
12 8 
13 6 
GND 14 


2.4 INTERRUPT AND DMA OPTIONS. | 
The AM-100 provides seven levels of DMA or eight levels of 
interrupt capability. The interrupt and DMA signal lines to 
the S-100 bus are user selected with jumper wires applied to 
the circuit board. These jumpers select the desired vectored 


interrupts or DMA grant signals. 


2.5 SYSTEM CONNECTIONS. 

The AM-100 board set plugs into two adjacent slots in a S-100 
Bus chassis and are connected together by a 40 pin flat cable 
along the top of the circuit boards. An additional input must 
be connected to the real time clock of the CPU. This can be 
Supplied from the 50 or 60 Hz power of the low voltage power 
supply in the S-100 bus chassis. Connect this 50 or 60 Hz 
Signal to CPU board 2 at header U3 pin 12 according to the 
following procedure as shown in Figure 2-2. The AM-100 is 
then ready for use. 


Make sure AC power is off and chassis is unplugged. 


Locate the secondary transformer tap supplying the +8 
volt rectifier. The accompanying schematic illustrates 
this point for the TEI MCS-122 chassis. 


Locate the E-Z hook cable supplied with the AM-100 CPU 


board set. 


Cut one end off the cable so that it is long enough to 
reach from the top of the AM-100 CPU set to the transformer 
tap connection located in Step 2. (Make sure that the 


cable is long enough to be conveniently routed.) 


Solder the cut end of the cable to the transformer tap 


connection. 


Before attaching the cable to the AM-100, perform the 
following steps: 


a. Plug in the chassis and turn on AC power. 


b. Observe the waveform at the "E-Z" hook contact. It 


Should appear as a+ 10 volt signal at 60 or 50 Hz. 


If the waveform at Step 6b appears correct, turn off AC 
power, attach the "E-Z" hook to CPU board #2 at J3 pin 4. 
An extended resistor lead is provided for convenience in 


hook-up. 
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Figure 2-2. 
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Real Time Clock Connection 


SECTION 3 
PROGRAMMING 


3.0 INTRODUCTION. 

This section provides information for programming the AM-100 
CPU and integrating it into the user's system. The actual 
software itself is not contained in this manual. Only the 
requirements and descriptions of the available software pro- 


grams and their capabilities are presented here. 


3.1 SYSTEM CONFIGURATION. 

A minimum system can consist of the AM-100 two board set, a 
minimum of 32K bytes of memory on a S-100 Bus memory board, 
a serial I/O card such as the AM-300,a disk memory, and a 
terminal. A PROM is needed to bootstrap the system and this 
can be located on one of the peripheral interface boards. 


Other standard Alpha Micro devices include: 


Floppy disk subsystem (AM-200/AM-210). 

Ten megabyte hard disk (AM-500). 

Large storage capacity hard disk (AM-400/AM-410). 
Tape storage subsystem (AM-600). 


RB WN 


To utilize other devices in the system, it is necessary to 
write a driver program for the device and place the resulting 
module in a preassigned disk area. The bootstrap PROM can 

be located on either the floppy controller interface board 
(AM-200) or the hard disk controller interface board (AM-500 
or AM-400). The starting address for the bootstrap program 
1s jumper selectable on a platform header on CPU Board 1, U3. 


The standard addresses used in Alpha Micro systems are listed 
in Table 3-1 and boot addresses are listed in Table 3-2. The 
standard DMA levels are listed in Table 3-4 and the standard 
interrupt levels are listed in Table 3-5. For further details 
on interfacing Alpha Micro circuit boards, consult the 


Technical manual for the individual board. 


Table 3-1. Alpha Micro I/O Addresses 


| Address (Hex) 


00 


a 


3C 


50 


= 


80 


84 


AO - Al 


A8 - AF 


BO - BE 


C8 - CF 


C3 
i) 


Interface 


Reserved 


Unassigned 


Reserved 


| Memory Bank Switching (1 port/memory bd) 


Unassigned 


aes Link (DC Hayes bd) 


Imsai PIO (parallel port, Data I/O control, etc.) 


ICOM Floppy Controller or AM-500 Disk Controller 


(4 ports/bd) 


| oo 


Unassigned 
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Table 3-1 (Cont.). Alpha Micro I/O Addresses 


AM-300 6 Port Serial I/O Board 


AM-200 Floppy Controller or AM-210 Floppy 
Controller 


Table 3-2. Boot Addresses 
F400 AM-500 Boot Address 
- Boot Address 


FCOO 


Boot Address 
Boot Address 
| AM-400 Boot address 


| C000 ICOM Floppy Boot Address 


TABLE 33s. DMA Levers 


AM-600 Mag Tape Controller 


AM-200 Floppy Controller 


Table 3-4. Interrupt Levels 


“Wee 


AM-310 4 Port Communications Board 
AM-410 Disk Controller 


AM-300 6 Port Serial I/0O 
AM-500 Disk Controller 


Not available on old systems 


Level 


Cth * 
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3.2 SOFTWARE OVERVIEW. 

A wide variety of software programs are available for use 
in the AM-100 system that have been operating in the con- 
mercial environment for many years. These programs have 
been written under copyright solely by Alpha Microsystems 
and are available in either floppy disk or hard disk form. 


5.2.1 OPERATING SYSTEM. 

The operating system is a commercial, full multi-tasking, 
timesharing system capable of supporting as many job partitions 
as memory capacity will allow. Each job may be controlled 

by its own terminal or several jobs may be controlled by the 
Same user terminal under a unique software control system 
built into the monitor. One job may also control several 
terminals. The status of each job may be optionally displayed 
on a central video display interfaced through a controller. 


The I/O structure is fully device independent and contained 
within the monitor. To incorporate a new device into the 
system, the user creates a software driver to interface to 


the device and includes it in the monitor. 


The terminal service routines are also device independent 

and operate through terminal drivers. Each terminal driver 
contains a software translation routine to allow the use of 
Special terminal functions such as cursor address and common 
I/O routines to all types of terminals, without being dependent 
on which brand of terminal is attached to the system. 


5.2.2 ASSEMBLY LANGUAGE PROGRAM. 
The assembly language program development system includes: 


1. <A multi-phase macro assembler. 
Z. <A linking loader. 
3. A symbolic debugger. 


Seles 


TEXT EDITORS. 


Two text editor programs are included: 


5.2.4 


A character oriented editor. 
A cursor-controlled screen editor. 


UTILITY AND SUPPORT PROGRAMS. 


Utility and support programs are available that include: 


SIO MO SPW NHN Fe 


Sei Zieo 


File maintenance programs. 

Dump programs. 

Memory test programs. 

Device test programs. 

Line printer spooler system. 

Dynamic System status monitor programs. 

A system generation procedure that allows custom 
tailoring of the monitor to individual user 
requirements. 


Text formatting. 


ALPHABASIC PROGRAM. 


The AlphaBasic programming language processor is a full com- 


piler that is disk oriented and supports: 


FW NY Fe 


Strings. 

Multi-dimensioned arrays. 

Disk I/O file accessing. 

A unique variable mapping system for file manipula- 
tion in applications programs and for assembly 
language subroutine processing. 

Assembly language subroutines. 


Terminal independent cursor control. 
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The AM-100 utilizes floating point hardware so it typically 
runs several times faster than other Basic systems. It is 
precise to eleven decimal digits using a three-word binary 
floating-point format which is identical to that used by the 


WD16 instruction set. 


3.2.6 ACCOUNTING PACKAGE. 


An accounting package is available under special license that 


includes: 
1. General ledger. 
2. Accounts receivable. 
3. Accounts payable. 
4. Order entry-inventory control. 
oS Payroil. 


Each of these is a fully interactive, menu-driven, complete 
system by itself. However, interface is provided between all 


five modules to create a totally integrated accounting package. 


3.2.7  ALPHALISP. 

An Alpha Micro version of the programming language LISP is 
available. It is designed for users that require a language 

that is both a formal mathematical language and (with extensions) 


a convenient programming language. 


3.2.8 ALPHAPASCAL. 

ALPHAPASCAL is a systematic procedure-oriented, structured 
programming language that is available. Adapted from the 

UCSD/PASCAL system, ALPHAPASCAL utilizes a dynamic paging 

system that allows the system to run in a small amount of 


memory. 


SECTION 4 
FUNCTIONAL THEORY OF OPERATION 


4.0 INTRODUCTION. 

This section describes in detail the functional theory of 
operation of the AM-100 Central Processor Unit (CPU). The 
first part of this section provides a general description 

of the configuration of the CPU and its integration into an 
S-100 Bus system. The second part describes the details of 
CPU operation and how the CPU chip set operates with its 
associated logic elements. The third part provides a complete 
description of the CPU chip set and the fourth part describes 
the operation of the individual logic elements that support 
the CPU chip set. 


4.1 CPU CONFIGRUATION. 

The AM-100 circuit cards function as a 16-bit CPU that plugs 
in to an S-100 Bus system. The data processing logic is 
contained on a two-board set that is fully integrated into 
an S-100 Bus system. 


4.1.1 AM-100 TWO-BOARD SET. 

The AM-100 CPU is packaged on two circuit boards connected 
together by a 40-conductor flat ribbon cable. Both boards 
mate with the standard 100 pin connectors in the S-100 Bus 


system. 


One Circuit board, CPU No. 1, contains the CPU chip set that 
consists of five 40-pin MOS/LSI chips. This chip set contains 
the necessary data processing capability for CPU operation. 
The second circuit board, CPU No. 2, contains the logic that 
interfaces the 16-bit bus of the CPU to the 8-bit S-100 bus 
plus the DMA and interrupt logic. 


The CPU chip set contains six 16-bit accumulators/index 
registers, a stack pointer and program counter, eight address- _ 
ing modes, hardware SAVE and RESTORE, and hardware floating 
point arithmetic. | + 


4.1.2 S=+100 BUS OPERATION. 

The S-100 Bus system is the single bus computer architecture 
that supports the AM-100 CPU and its associated memory and 
peripherals. The I/O connectors are standard 100-pin type and 
each of the 100 lines are bussed together throughout the com- 
puter chassis. 


The S-100 bus is an eight-bit format with eight bits of tri-state 
‘data for CPU input, eight for CPU output, 16 bits for address, 
and various control, status, and utility lines. There are also 
eight lines for vectored interrupts/DMA requests and eight for 
DMA Grant lines. The various devices connected to the bus are 
referred to as bus master and bus slave depending on the opera- 
tional configuration taking place. The CPU is not the only 
device that can control the bus. Any DMA device has the capa- 
bility of controlling the bus as a bus master. 


The command and control lines determine the timing of the 

bus and are listed in Table 4-1. The status lines are asso- 
Cliated with the address lines and indicate what type of bus 
cycle is taking place. Any bus master must generate these 
Signals or at least ensure that the unasserted level is 
maintained. The AM-100 status lines are listed in Table 4-2. 
The utility lines are clocks, power, and initialization and 
are listed in Table 4-3. 


Table 4-1. S-100 Bus Command/Control Lines 


SIGNAL NAME 


Processor Sync 


Data Bus In 
Write Strobe 
P-Hold Acknowledge 


Processor Hold Request Line 


Table 4-2. S-100 Bus Status Lines 


SIGNAL NAME 


Bus Master OP Code Fetch 
I/O Output Cycle 

I/O Input Cycle 

Memory Read Cycle 

Bus Master Output 


Interrupt Acknowledge 


Table 4-3. S-100 Bus Utility Lines 


SIGNAL NAME 


GND, +8VDC, +16VDC, -16VDC 
2 MHz Phase 2 Clock 
2 MHz Clock 


Memory Write 


Preset 


Power-On Clear 


Read Timing. The timing of the signals involved with a READ 
BYTE sequence on the S-100 bus is shown in Figure 4-1. When 
an I/O operation takes place, PSYNC is generated as the first 
State of the bus cycle. Signal PDBIN is next to indicate that _ 
a read operation is taking place. Address lines are valid 
shortly after PSYNC and remain so until the next bus operation. 
The addressed memory or peripheral has 400ns to place its data 
on the bus for the read cycle. Once the CPU reads the data, 
PDBIN is lowered, ending the cycle. The READ WORD cycle is 

a Similar sequence twice because two bytes are read. Timing 


for the READ WORD sequence is also shown in Figure 4-1. 


Write Timing. The timing of the signals involved with a WRITE 
BYTE sequence on the S-100 bus is shown in Figure 4-2. With 
this sequence, PSYNC starts the bus cycle like the read timing. 
Signal PWR occurs next to indicate that there is valid data 

on the bus that is to be written into the addressed location. 
Status and address data is placed on the bus < 100 nsec after 
PSYNC by the bus master. The WRITE WORD cycle is a similar 
sequence twice because two bytes are written as shown in Figure 
4-2, 


Read-Modify-Write Timing. The READ-MODIFY-WRITE cycle combines 
these operations into a single sequence as is shown in Figure 
4-3, 


DMA Timing. The timing and sequence for a DMA cycle is shown 
in Figure 4-4. The selected vector interrupt signal initiates 
this cycle and it is acknowledged by DMARCVD. The selected 
DMAGRANT signal indicates an active DMA cycle and the busses 
are active < 50ns later. 


4-4 


READ BYTE TIMING 


—+ = 500 NS TYP. 
oO TU ra. 


PSYNC | | 


<100 NS —| 
PDBIN A\ 
—>| 2400 NS 


STATUS & ADOR 


2800 NS ——>| 
CATA READ | | 


READ WORD TIMING 


—| J+ —500 NS TYP. 
ee ee 


PSYNC | | | 


<100 NS | <100 NS 


PDBIN 


2200 NS 


STATUS & ADDR 


LOW BYTE HI BYTE 


>600 NS —»| l— 


2800 NS aa 


DATA READ 


PDBIN MAY BE STRETCHED BY CONTROLLING PRDY. 
PRDY IS EXAMINED AT $1 (WD) LEADING EDGE 
TIME DURING PDBIN. 


Figure 4-1. S-100 Bus Read Timing 
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WRITE BYTE TIMING 


STATUS & ADDR 


WRITE WORD TIMING 


= -— 500 NS TYP 
gee PL. 


PSYNC | A\ | | | 


<100 NS —> —r| |«—<100 Ns 
>100 NS —| 7100 NS 
>100 NS >| >100 NS 
STATU | 
S & ADDR th quoweere HIGH BYTE 


DATA LOW BYTE HIGH BYTE 


PSYNC MAY BE STRETCHED ONE OR MORE CYCLES 
DUE TO DOUT DELAY CAUSED BY MICROCODE. 


G\ rar MAY BE STRETCHED BY CONTROLLING PRDY. 
PRDY IS EXAMINED AT $1 (WD) LEADING EDGE 
TIME DURING PWR. 


Figure 4-2. S-100 Write Timing 
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READ-MODIFY-WRITE BYTE TIMING 


—>| | — soonstvP 


$, (8080) 


SYNC 


, Ly 
<100 ns— —| <100 NS 


PDOBIN 


2200 NS 


DATA READ/OUT ea 


2600 NS — Paes a 
2 


PWR 
STATUS & ADDR READ WRITE 
READ-MODIFY-WRITE WORD TIMING 
— [+ — 500 NS TYP 
¢, (8080) 


PSYNC A\ 
<100 NS—o —| <100 NS —+| <100 NS —| <100 NS 


PDBIN 
2200 NS 2400 NS 
DATA READ/OUT LOW BYTE |X HIGH BYTE 
>600 NS >800 NS ——| — A100 NS]! S100 Ns 
—>| 2100 NS 


STATUS & ADDR ~ | LOW BYTE HIGH BYTE LOW BYTE _ HIGH BYTE 


PWR 


PSYNC MAY BE STRETCHED ONE OR MORE CYCLES DUE TO 
DOUT DELAY CAUSED BY MICROCODE. 


AN PDBIN AND PWR MAY BE STRETCHED BY CONTROLLING PRDY. 
PRDY IS EXAMINED AT $1 (WD) LEADING EDGE TIME DURING PDBIN OR PWR. 


Figure 4-3. S-100 Bus Read-Modify-Write Timing 
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DMA TIMING 


—| k— 500 NS TYP 
em Uk 


Viy 
DMARCVD (0, WD) s 


DMAGRANT, | 


| <100 NS 


ALL CPU 
BUSSES TRISTATE 


<60 Ns —+ 


_— <100 NS 


L\ DMAGRANT MAY BE DELAYED IF A 8US CYCLE IS IN 


PROGRESS WHEN A DMA REQUEST IS GENERATED. 
iT WILL BE ISSUED IMMEDIATELY FOLLOWING 
THE COMPLETION OF SYNC. 

2. PHOLD IS ALWAYS FORCED LOW. 


3. PHLDA IS ALWAYS HIGH. 


Figure 4-4. S=100 Bus DMA Timing 
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For a complete description of the S-100 bus signals in the 
AM-100 system, refer to Table 4-4. This table lists all 
Signals in alphabetical order with AM-100 pin numbers and 
also the sheet number of the schematic where they interface 
with the AM-100 CPU. A complete description of each signal 
1s also given. 


OL“ 


SIGNAL | NAME 


Address 
Address 
Address 
Address 
Address 
Address 
Address 
Address 
Address 
Address 
Address 
Address 
Address 
Address 
Address 
Address 


2 MHz Clock 


Table 4-4. 


SCHEM 
PAGE 


CPU1-9 
CPU1-9 
CPU1-9 
CPU1-9 
CPU1-9 
CPU1-9 
CPU1-9 
CPU1-9 
CPU1-10 
CPU1-10 


CPU1-10 


CPU1-10 
CPU1-10 
CPU1-10 
CPU1-10 
CPU1-10 


CPUZ-3 


S-100 Bus Interface Signals List 


DESCRIPTION 


16 bits of tri-state addressing. 


2 MHz clock from same source as @2., 


[lv 


Table 4-4 (Cont.). S+100 Bus Interface Signals List 


SIGNAL |NAME 


Data Input Bus 
Bits 0-7. 


DMA Grant 


DMARCVD|DMA Received 


S CHEM 
PAGE 


CPUZ=5 


DESCRIPTION 


Data input port. Eight bit tri-state data bus 


from bus slave to bus master. 


Grant signal issued to the highest priority 


controller that has requested the bus. 


CPU response to DMA request indicating that a DMA 


exchange is in process. No other DMA controllers 
may issue a DMA request while DMARCVD is asserted. 


Table 4-4 (Cont.). S=#100 Bus Interface Signals List 


| SIGNAL | NAME J1 S CHEM DESCRIPTION 
| PIN NO.| PAGE 


Data output port. Eight bit tri-state data bus 


Data Out Bus 
Bits 0-7 


from bus master to bus slave. 


Only used internal to the AM-100 


| 
— | ENDF 18 | cPu2-2 


MWRITE oer a CPU2-2 Gated combination of PWR and SOUT. 
_ fp — 


PHLDA P= Hold | CPU2- 3 When asserted, indicates that the CPU is 
releasing control of the bus in response to a 
DMA request (PHOLD). (This signal is forced 
high by the AM-100 and not used.) 


Read Hable: Used by bus master to request 
address slave to place data on the data bus, 


SIGNAL 


PHOLD 


PINTE 


POC 


PWAIT 


Table 4- 


NAME 


DMA Request 


CPU Interrupt 


Enable 


Power On Clear 
Processor Ready 


CPU Wait 


4 (Cont.). S-100 Bus Interface Signals List 


SCHEM DESCRIPTION 
PIN NO.| PAGE 


Used by DMA controllers to request bus master- 
Ship. (This signal.is held low by the AM-100 


and not used.) 


Output from CPU to enable slave interrupts 


(not used by Alpha Micro Systems). 


Clear signal generated oe the CPU on 


initial turn on. 


_ CPU2-8 When low, increases the duration of PDBIN or PWR. 
CPU2Z-2 Reset signal normally originating from front 
panel reset pushbutton. © 
Ea CPU2-7 When asserted, indicates the start of a bus cycle, 


CPU2-7 | When asserted, indicates that the CPU is ina 


wait period. 


vL-v 


| be 
Poa 
rd 


SIGNAL 


SINTA 
SMEMR 
SM1 


SOUT 


ep) 
= 
© 


—) 


Table 4-4 (Cont.). 


NAME 


1/O Input Cycle 
Interrupt 
Acknowledge 
Memory Read Cycle 
Bus Master | 

OP Code Fetch 


I/O Output Cycle 


Bus Master 
Output 


J 
P 


1 
IN NO.}| 


| a > a “I 
wn ~) On ~~ 


Ps 


WO 
~“ 


S CHEM 
PAGE 


CPU e] 


GPUZ=/ 


CPUZe7 


CPUZ=/ 


CPUZ= 7 


CPUZ=/ 


CPU2Z-7 


S-100 Bus Interface Signals List 


DESCRIPTION 


When asserted, is a command from the bus 
master for the addressed slave to accept the 


data on the data bus. 


When asserted, indicates that the current bus 


cycle is a bus master input from an I/O address. 


When asserted, indicates acceptance by bus 


master of an interrupt request. 


When asserted, indicates that the current bus 


cycle is a bus master input froma memory address.| 


When asserted, indicates that the current bus 


cycle is a bus master OP code fetch. 


When asserted, indicates that the current bus 


cycle is a bus master output to an I/O address. 


When asserted, indicates that the current bus. 


cycle is a bus master output. 


Table 4-4 (Cont.). S-100 Bus Interface Signals List 


SIGNAL | NAME J1 S CHEM DESCRIPTION 
PIN NO.| PAGE 


Vectored Interrupt Vectored interrupt lines used for both 


Vectored Interrupt 


interrupt requests and DMA requests. 
Vectored Interrupt 
Vectored Interrupt 


| Vectored Interrupt 


(Oo CON ND HN & 


Vectored Interrupt 


Vectored Interrupt 10 


ND OT HP WN NH F OC 


Vectored Interrupt 


> 
i 
fond 
a STVAL Status Valid CPU2-3 Indicates Status § Address lines valid 
during PSYNC. 
XRDY External Ready os CPU2-8 When low, increases the duration of PDBIN or PWR. 


Phase 2 Clock CPU2-3 2 MHz clock Phase 2. Master Timing signal for 
the bus. 


+8vdc power 


System power and ground. 


+16 vdc power 


-16 vdc power 
Gnd 


4.1.3 CPU CHIP SET. 
The CPU chip set consists of five 40-pin MOS/LSI chips that 
include a data chip, a control chip, and three microms. A 
detailed description of the operation of the individual chips 
1s contained in paragraph 4.3. The chip set utilizes 16-bit 
architecture with both word and byte operation. Since the 
S-100 Bus is an eight-bit system, further data processing is 
required for compatibility and this is described in paragraph 
4.2. The primary features of the chip are as follows: 


a. 16-bit architecture with both word and byte 
operation. 
16-bit data access port to memory and I/O. 
c. Eight 16-bit registers. 
d. Four external interrupts. 
Three internal interrupts. 


f. Eight addressing modes. 


The chip set is microprogrammable by the coded data within the 
microms. Figure 4-5 contains a block diagram of the five chips 
in the CPU chip set. 


4.1.3.1 DATA CHIP. 

The data chip provides the interfacing capability for data 

and addressing. A 16-bit Data and Address bus (DAL) interfaces 
the CPU to external logic. It also contains eight 16-bit 
registers, the Arithmetic Logic Unit (ALU), microinstruction 


bus lines, and some microinstruction decoding logic. 


CHIP 


SELECT M1B18-M1B21 
512 x 22 
MICROM 
CHIP NO. 1 
CP 1631-27 
oe i CLOCK U30 MIBO- 
MIB15 
CHIP 
SELECT TO STATE 
CODE DECODER 
512 x 22 
MICROM 
CP 1631-29 
CHIP 
SELECT 
sxe |_| | 
MICROM 
CP 1631-30 
CONTROL CHIP DATA CHIP DALO-DAL15 
RESET CP 16618 CP 1611.B 
U28 U29 
10-13 


RPLY 
BUSY 
_SYNC 
DIN 
DOUT 
wB 


IACK 


Figure 4-5. CPU Chip Set 


4.1.3.2 CONTROL CHIP. - | 
The control chip contains the microinstruction address register 
which controls accessing of the microinstructions. It also 
contains translation array logic and the interrupt logic. 

The master timing control is directed by the control chip which 
indicates when an address is valid on the DAL lines and indi- 


cates a read or write operation and a byte or word operation. 


4.1.3.3 MICROM CHIPS. 

The microm chips are 512 word by 22 bit ROMs which are programmed 
to Alpha Micro specifications. These 22-bit outputs comprise 

the microinstruction bus (MIB) that allows the chips in the CPU 
to communicate with each other (MIBOO-MIB21). Each ROM location 
contains a 16-bit microinstruction, two control bits, and four 
auxiliary bits. The 16-bit microinstructions and the two control 
bits form a high impedance tri-state bus. Bits MIB18-MIB21 are 
the auxiliary bits and are the state codes that direct external 
logic to perform special functions. 


4.1.3.4 MICROINSTRUCTION BUS. 

The Microinstruction Bus (MIB) is a high impedance MOS bus for 
data transmission between the chips in the CPU and is very | 
sensitive to external monitoring even with oscilloscope probes. 
The capacitors located on CPU 1 suppress noise and optimize 


data transmission on the bus. 


Bits MIBOO-MIB10 serve a dual purpose. During the portion of 
the cycle that addresses the microinstruction from the microm, 
these bits contain the 11-bit address. During another part of 
the cycle, they are used to transmit the microinstruction to 
the other chips. Bits MIB11-MIB17 just transfer part of the 
microinstruction. Therefore, during the address phase, MIBOO- 
MIB10 address the microinstruction and during another phase 
MIBOO-MIB17 transfer the microinstruction. 


Timing of the microinstruction bus is shown in Figure 4-6. 

The four phases are running continuously, and phase two places 
the address of the next required microinstruction on the MIB 
in bits 0-10. This address data comes from the control chip. 
Phase three decodes the microinstruction. Phase four provides 
the precharge necessary for the nodes since this is a MOS bus. 
At phase 1, the microinstruction is placed on the bus and the 


process repeats. 


The function of the state codes and operation of the CPU with 


its associated external logic is described in paragraph 4.2. 
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OC -0 


$1 


db 


@ 


MICRO- ADDRESS MICRO- FRECHARGE MICRO- 


INSTRUCTION FROM INSTRUCTION FOR NEXT INSTRUCTION 
PLACED ON CONTROL DECODING CYCLE AND PLACED ON 
BUS CHIP DURING $3 MICRO- BUS 
DURING $1 PLACED INSTRUCTION DURING $1 
N BUS IS ACCESSED 
DURING $2 . 


*Except for MIB15 which is precharged at 93. It is used to 
transfer conditional jump results back to the control chip 


during 4. 
MIB16 is precharged during $2 and #4. It is conditionally 
discharged during $1 to control RR register, and conditionally 


discharged during $3 to disable microm output buffers. 


Figure 4-6. Microinstruction Bus Timing 


4.2 CPU OPERATIONS. 

The AM-100 CPU board set consists of the CPU chip set and 
associated logic elements that provide data processing capa- 
bility for the S-100 bus system. This Section describes 
operation of the CPU in the system and operation of the CPU 


chip set with its associated logic elements. 


An overall block diagram of the CPU board set is shown in 
Figure 4-7. Sheet 1 contains all the logic on CPU board 1, 
‘and sheet 2 contains all the logic on board 2. Table 4-5 
contains a complete list of the signals in the AM-100 CPU. 
The list is alphabetical by signal mnemonic, and a description 
1s given for the function of each signal and the location 


where it can be found on the schematic diagram. 
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Figure 4-7. AM-100 Functional Block 
Diagram (Sh 1 of 2) 
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Table 4-5, AM-100 Signals List 


BOARD SCHEM PAGE 
SIGNAL NAME PIN NO.| OF SOURCE FUNCTION 


BDALOO- Buffered Data and CPU1-8 Internal tri-state bus for Data and Address Lines, 
BDAL15 Address Lines 


BUSY Busy CPU1-5— Asserted when any of the seven vectored interrupts 
CPU2-5 (VIO-VI6, PHOLD) are received. Indicates that a 
DMA exchange is in process. 
2 MHz Clock = CPU2-3 Output of 2 MHz clock. 


CPU1-4, Tri-state bus for Data and Address Lines. 
Og. 37 


DBIN Data Bus In CPU2-8 Read Enable equivalent to PDBIN on S-100 Bus. 
DBIN Enables CPU to read data from the Data In Bus. 
DIN Data In 1 5 CPU1-5 Control signal from the processor to cause the 
DIN Z CPU2-6 address unit to gate its read data on the data lines. 
DOUT Data Out CPui-5 | Control signal from the processor which is made high 
CPU2-3 at the same time that the write data is placed on 
the DAL bus by the processor. 


EARS External Address CPU1-7 Output of the state code decoder that reads the 
Register Select Z 3 CPU2-4 starting address of the bootstrap PROM. 


Table 4-5 (Cont.). AM-100 Signals List 


FUNCTION 


FIVE | Sequencer Count Five 


(TI 
Zz 
= 
oe) 


2 


CPU2-9 Sequencer output for count five. 
FOUR Sequencer Count Four CPU2-9 Sequencer output for count four. 
FOUR 


ped 
© 


CPU1-5 
CPU2Z-6 


Used for CPU interrupt I[3. 


Halt - 
| | Zs 


High Byte 


CPU2-2 Output of real time clock header used to generate 
HALT for CPU interrupt [3. 


HALT 
HALTA 


HIBYTE 
HIBYTE 


When asserted, switches the upper byte (bits 8-15) 
to the output port from the WD16. When it is low, 
| the lower byte (bits 0-7) is selected. 


Control signal output from the CPU to indicate that 


GPUL=5 
CPUZ=7 


Interrupt 


Acknowledge | the processor is responding to an interrupt. 


KO 
On 


— “I WG 
WN | ( 


CPUL=10 
GPUZ=5 


Initiate Address 
AO 


Sequencer output to generate LSB of address byte 
in either bit AO or A8. 


IDIN 


oS) 
Co 


| Enable signal to 
VINTRI-VINTR3 to 


Interrupt Data In apply stored vectored interrupts 


Data and Access Lines DAL1-DAL3. 


INTFF | Vectored Interrupt 


CPU1-5 | CPU vectored interrupt IO. Asserted with any of the 
Input Z | CPU2-6 vectored interrupts. | 


Table 4-5 (Cont.). AM-100 Signals List 


BOARD J2 SCHEM PAGE 
SIGNAL NAME | NO. PIN NO.}]OF SOURCE FUNCTION 
I/O Selected CPU1-9 Asserted for an I/O data transfer. False for 
CPU2-7 a memory transfer. 


Input Status Register CPU1-7 Generated by State Code 6 (SC6) to apply the status 
PCrue- 4 data to the DAL bus bits DALO-DAL7. 
= Interrupt 2 Interrupt signal set by State Code 4 (SC4) and 


cleared by State Code 5 (SC5). Serves as an Inter- 
I2FF CPU Interrupt 12 
JFIVE Set Sequence 5 | 


JFOUR Set Sequence 4 


cco Set Sequence Rest | CPU2- 8 J input to eae flip- Elop zero (REST). 
JSEVEN set Sequence 7 | ee CPU2-9 J input to sequencer flip-flop 7. | 
JTHREE | Set Sequence 3 oe j.|_t CPU2Z-9 J input to sequencer flip-flop 3. 


,| CPU1- 25 394,5 Data bus to transmit data between the five chips at 
the CPU chip set. 


rupt enable for vectored interrupts. 


CPU vectored interrupt I2 generated by any 
vectored interrupt. 


| CPUZ-9 J input to sequencer flip-flop 5. 


J input to sequencer flip-flop 4. 


Ne) i) br bho bm BE | be 
; 7) 
: we) 
aoe 
Jd 


~Microinstruction 


Bus Bits 0-21 


~ MSYNC1 
MSYNC1 


M Sync One State one of the sequencer. 


PHLDA -P-Hold Acknowledge i 2 - | CPU2-3 When asserted, indicates that present bus master is 
| | oo -_ releasing control of the bus in response to a DMA 
request (PHOLD) (forced high and not used). 


4-29 


Table 4-5 (Cont.). AM-100 Signals List 


SCHEM PAGE 
SIGNAL NAME 
PHOLD DMA Request Line 


= Power On Clear 


CPU2-3 Inverse of Power On Clear. 


PSYNCI | Processor Sync 


FUNCTION 


Used by DMA controllers to request bus mastership 


(forced low and not used). 


Pulse signal asserted on initial power-up and by 
PRESETB signal. 


Indicates the start of a bus cycle, used to generate 
Internal PSYNC on S-100 BUS. 

Address data bit zero stored from the DAL bus clocked 
into the register by SYNC. 


Stored Address Zero 


Address Data stored from the DAL bus clocked into 
the register by SYNC. 


Stored Address 


af —— zz 
{ READWORD {| Read Word cz 


State Code decoder signal for Read Byte operation. 


State code decoder signal for Read Word operation. 


Sequencer aint indicating that the CPU dis Set 115°. 
ready to accept data. 


‘The state of the sequencer when no instruction or bus 


operations are taking place (state 0.of the sequencer). 


RMW | Read-Modify-Write | ) es CPUZ-4 State code decoder Signal for Read Modifty- -Write eidinex 
ee _ ar | 7 word or byte. 


SIGNAL | NAME 


Read-Modify- 
Write-Byte 


RMWB 


RMWB 


RMWW 
RMWW 


RPLY 


RTCFF 
SC1-SCF 


RST 

RTC 
SEVEN 

sm 
SOUT 
SOUT 
SYNC 


SYNC 


Read-Modify- 
Write-Word 


Reply 


CPU Reset 
Real Time Clock 


CPU Real Time Clock 


Sequencer Count Seven 


Sequencer Count Six | 


State Codes 1-F (Hex) 


I/O Output Cycle © 


sync 


Table 4-5 (Cont.). AM-100 


BOARD 
NO. 


Z 


Z 
y) | 
Z 


a SCHEM PAGE 
PIN NO.|OF SOURCE 
a - 
7 _ 
leet 
_ 

~ ieee 
- = 

6 CPU1-5 

CPU2-4 


Signals List 


FUNCTION 


Generated during an INPUT BYTE micro op code with RMW 


active to indicate a Read-Modify-Write byte sequence 
(1010 Microcode). 


Generated during an INPUT WORD micro op code with RMW 
active to indicate a Read-Modify-Write word sequence 


(1001 Microcode). 


Control signal used by the addressed unit to respond 


to the processors data access signals. 


Resets CPU chip set on initial power-up. 


Real time clock input to CPU. 


When asserted indicates that the current bus cycle 


is a bus master output to an I/O address. 


Output of the CPU chip set indicating the start of 
an I/O operation. 


Outputs of state code decoder. 
Sequencer output for count seven. 
Sequencer output for count six. 


Table 4-5 (Cont.). AM-100 Signals List 


BOARD| J2 |SCHEM PAGE| | 
NO. | PIN NO.| OF SOURCE FUNCTION 


CPU2-9 Sequencer output for count three. 
CPUL=6 
CPU2-6 


SIGNAL 


THREE 
THREE 


Sequencer Count Three 


Vectored interrupt level one signal for the DAL bus. 


GN 
Joel 


= | 
oN Le) 


Vectored Interrupt 1 


VINTR 1 


VINTR 2 


WG 


Vectored Interrupt 2 Vectored interrupt level two signal for the DAL bus. 


CPU1-6 


VINTR 3 Vectored Interrupt 3 Vectored interrupt level three signal for the DAL bus, 


CPU2Z-6 


Write Operation CPU2-7 Indicates that the current process is a write 


operation. 


WAIT Wait Signal from CPU data chip to control chip to establish 
whether the data chip is in the Run or Wait mode, 

Low = Run, and the microinstruction is loaded and 

executed. 
CPU1-5 Control signal from the processor which is high when 
CPU2-3 the address is on the bus to signify a WRITE rather 
than a READ and high during Data Out to signify BYTE 


rather than WORD. 


_ 


GCPUZ=3 


Write Byte Output 


Write Byte signal clocked by DOUT. 


_ 
WBFF 
 WBFF 
| XDMAG 


CPU1-8 | Controls the buffers that interface the CPU control 
CPU2-5 signals with the S-100 bus to allow them to be removed 


when another master is controlling the bus. 


XDMA Grant 


SIGNAL 


XDMA GRANT 


= 
a 


01M 


S| 
Ne) 


§2B 


02M 


03M 


Q4M 


XDMA Grant 


Phase 1 Clock 


Phase 1 Clock, 


MOS Levels 


Phase 2 Clock 


Phase 2 Clock 


Phase 2 Clock, 


MOS Levels 


Phase 3 Clock 


Phase 3 Clock, 


MOS Levels 


Phase 4 Clock 


Phase 4 Clock, 
MOS Levels 


Table 4-5 (Cont.). 


BOARD | 


NO. | PIN NO.| 


( ' 
! bs ND 4 ba = 


OF SOURCE 
CPU1-10 
CPU2-5 
CPU1-1 
CPU2-2 
CPU1-1 
CPU1-1 
CPU2-2 
CPU2-8 


CPULet 


GPUS. 
GrUZeZ 


GPULe= 1 


SCHEM PAGE | 


AM-100 Signals List 


FUNCTION 


Same as XDMAG. 

Phase 1 of 2 MHz 4-phase clock see Figure 4-8. 

Phase 1 of 2 MHz 4-phase clock buffered for 10.5 

volt operation of CPU chip set. 

Phase 2 of 2 MHz 4-phase clock see Figure 4-8, 

Phase 2 of 2 MHz 4-phase clock buffered for operation 


sequencer flip-flops. 


Phase 2 of 2 MHz 4-phase clock buffered for 10.5 volt 
operation of CPU chip set. 


|} Phase 3 of 2 MHz see Figure 4-8. 


Phase 3 of 2 MHz buffered for operation 


| of CPU chip set. 


CPU1-1 


Phase 4 of 2 MHz see Figure 4-8. 


Phase 4 of 2 MHz 4-phase clock buffered for operation 


of CPU chip set. 
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4.2.1 CLOCK GENERATOR. 

The basic clock signals originate at the 4 MHz crystal 
oscillator US. Its output is divided-by*two by the Jek flip- 
flop U23, gated and buffered to generate clock signals #1, @2 
and CLOC. Clock §2 provides the S-100 Bus clock and CLOG 
drives the four-phase clock generator U12. The four phase 
clock generator provides the internal clock signals to drive 
the CPU chip set and to synchronize its associated logic. 
Operation of U12 is described in paragraph 4.4.1. The timing 
relationship of the S=100 bus clocks and the fourephase clocks 
is described in Figure 4-8. 


The TTL level clocks from CPU 2 are sent to CPU 1 where they 
are buffered through U2 and U3 to a level of at least 10.5 
volts to drive the CPU chip set. 


1 | | | | | 


$-100 BUS 


CLOCKS 
2 
o1 
2 
4-PHASE 
CLOCKS | 


Figure 4-8, AM-100 System Clocks 


4.2.2 STATE CODE DECODER LOGIC. 

The microinstruction state codes are contained in microinstruc- 
tion bits MIB18-MIB21 from the microinstruction bus in the CPU 
chip set located on CPU 1. These bits are buffered on CPU 1 
and then sent to decoders U7 and U8 on CPU 2. The information 
contained in these bits controls the type of processing to be 
performed. The decoder logic generates signals to control the 
input of the status register and control the sequencer to per- 
form the required processing operations (write, read, read/ 
modify/write). The state codes and their functions are 

listed in Table 4-6, 


4.2.3 SEQUENCER OPERATION. 

The sequencer on the AM-100 CPU provides the timing and syn- 
chronizing required to interface the 16 bit CPU chip set to 

the 8=bit S-100 Bus. There are ten states in this sequencer 


that provide the various operations required for CPU data pro- 


cessing, 

otate 7 Function 
0 Rest 
1 MSYNC1 - The sync signal for memory or I/O. 

oy DBIN = Input functions. Once around for byte, 

twice for word. 

4 Read-Modify=Write chain. 

Dg. Output functions. Once around for byte, twice 


for word. | 

HIBYTE LSB Address Control. 

READY Replies to the CPU and latches the upper byte 
of the DAL to the lower byte of the DAL during 
READ WORD operations. 


Table 4-6. Microm State Code Functions 


NAME 


Priority Mask Out. 


MNEMONIC FUNCTION 


CODE | 


0001 PMSK |The state code is generated on an OUTPUT WORD instruction when a new 


mask is written into location 2E. It signals the I/O devices that a 


new interrupt mask is on the DAL. (Not used on AM-100.) 


RUN Macro Instruction Fetch 


0010 


0011 


Generated during macro instruction fetch from memory for a run light. 
IORST | I/O Reset 


0100 


Enables the interrupt enable line I2. Sets I2 flip-flop. 


0101 


Disables the interrupt enable line I2. Resets I2 flip-flop. 


ESRR External Status Register| Generated during an INPUT STATUS BYTE micro op code to indicate that 


Request the external status register is being requested. 


0110 


1000 BYTE Read Byte Operation Generated during an INPUT BYTE micro op code to indicate a read byte 
operation without a read/modify/write. (Not used on AM-100.) 

1001 RMWW Read/Modify/Write Word Generated during an INPUT WORD micro op code with RMW active to 
indicate a read/modify/write word sequence. (Not used on AM-100.) 


1010 RMWB Read/Modify/Write Byte Generated during an INPUT BYTE micro op code with RMW active to 
| indicate a read/modify/write byte sequence. (Not used on AM-100.) 
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CODE 


1011 


1100 


1101 


1110 


1111 


MNEMONIC 


RLCI 


EARR 


Table 4-6. Microm State Code Functions 


NAME FUNCTION 


Controls where the CPU looks for the bootstrap PROM upon power up. 


Reset Line Clock 
Interrupt 


External Address 


Register Request 


Duplicate of BYTE Same as BYTE except one bit sooner. 3 


Duplicate of RMWW Same as RMWW except one bit sooner. 
| Same as RMWB except one bit sooner. | 


Duplicate of RMWB 


The flow diagram for sequencer operations is shown in Figure 

4-9 and the associated logic equations are shown in Figure 4-10. 
Each block on the flow diagram represents a flip-flop (CPU2 
schematic sheets 8 and 9). The J equations set the flip-flop 
on the next clock, and the K equations reset the flip-flop on 

the next clock. 


Note 
The sequencer clock is §2 from the four-phase 


clock generator. 


Timing diagrams for sequencer operations are contained in 
Figure 4-11 through 4-16. The timing relationships given 
Show the S-100 Bus timing on the top part of the diagram 
with the processor signals necessary to produce the bus 
Signals drawn underneath. Only one state of the sequencer 


is active at a time. 


On initial power up, the reset line (PRESETB) is forced low 
initializing the sequencer to the rest or zero state. The 


sequencer is in this state until a bus operation is required. 


When the CPU chip set is ready for an I/O operation, SYNC is 
asserted to generate MSYNC1 which is state one of the 
sequencer. When the Interrupt Acknowledge (IACK) line is 
true, the processor is not allowed to perform a bus operation. 
Input signals to the sequencer from the state code decoder 
and CPU then determine what type of sequence is required. 
Eight different sequences are possible as shown on Figure 4-9, 
The sequencer then proceeds through the required combinations 


of states as shown on the flow diagram. 


PRESET 


READ 
COMP 0 
REST 


SYNC - ACK 


1 
MYSYNC1 


(READ-MOD-WRITE) 


(WRITE) 


READ f(READY) f(READY) 
COMP 4 
DBIN 2 (RESTORE Ao) 
(READ) 7 | 
WORD: | ! 
[— HIBYTE | | [ey ee 
| | | | 
3 | Bo pe pee pee ae ee 6 
(FLIP Ao) | [— (1 BIT DELAY) 
| (7 BIT DELAY) | | | | 
ee oe Pe ae pee et (eee emer eee WORD - HIBYTE 
| | 
REST RES. | | | | 7 
| ; (FLIP Ao) 
| | 
| | | (1 BIT DELAY) 
Rah ae as ee a to , 
| 
ee , Fa 
ey eg es ad ei ee eed | 
| 
| 
| 
SEQUENCE OF OPERATION 
MODE STATES REPLY LOBIC* 
1. READY BYTE (MEM OR 1fO) 0-1-2-0 READY -RB-DIN 
2. READY WORD (MEM OR 1/0) 0-1-2-3-2-0 READY - RW -HYBITE - DIN 
3. WRITE BYTE (MEMOR I/O) 0-1-6 -6-0 READY -WB-5 
4, WRITE WORD (MEMOR I/O) 0-1-6-6-7-5-6-0 READY -WB-5-HIBYTE 
5. RMW BYTE (MEM) 0-1-2-4-5-6-0 1+3 ABOVE 
6. RWM WORD (MEM) 0-1-2-3-2-4-5-6-75-6-0 2+4 ABOVE 
7. RMW BYTE (1/0) 0-1-6-6-0 DIN+3 ABOVE 
8. RMW WORD (1/0) 0-1-5-6-7-6-6-0 DIN+4 ABOVE 


*STROBED AT $1 TRAILING EDGE AND GATED WITH SYNC, REPLY LOGIC 
GENERATES SIGNALS TO TERMINATE CPU CYCLE. 


Figure 4-9. Sequencer Flow Diagram 
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REST ee 
JREST = DBIN - SYNC - DIN+ 6 - SYNC 
KREST = JMSYNC, 


MSYNC, 
JMSY NC, = REST - SYNC - JACK 
KMSYNC, = JDBIN + J5 


DBIN 
DBIN = 3MSYNC, - DIN - (IOSEL [RMWB + RMWW]) 
KDBIN = JREST + J3 + J4 


J4 = DBIN- DIN - (RMWB - READY + RHWW - READY - HIBYTE) 
K4 = 4 - DOUT 


J5 = MSYNC, -DOUT + K4 +7 
K5 = J6 


J3 = READY -HIBYTE - DBIN - (RB + RMWB) 
K3=3 7 


J6=5- READY 
K6 = JREST + J7 


J7=6-WBFE-HIBYTE 
K7=7 


ADDRESS LSB LOGIC 
Ao = Ag) « (READWORD + Wg - DOUT) + HIBYTE - (READWORD + Wg - DOUT) 


HIBYTE BUS SIGNALS 
JHIBYTE - J3 + J7 PSYNC = MSYNC, +4+7+3 
KHIBYTE = J4 PWR =5 
DIR. RESET = REST PDBIN = DBIN 

SMEMR = IOWEL - SW, 

READY SINP = IOSEL - SW, 
JREADY = PRDY - XRDY - (DBIN + 5) SOUT = IOSEL - SW, 
KREADY = PSYNC +6 MWRITE = PWR - SOUT. 


DIR RESET = REST 


Figure 4-10. Sequencer Logic Equations 
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; —e = 500 NS TYP. 
pee UU 


PSYNC | | 
<100 NS —> j 


PDBIN 


STATUS & ADOR 


2600 NS —>| | 
DATA READ | | 


o2 (WD) | lr] l] [| r] [| i l] ] a [ a | i] 
SYNC ($2) | 
DIN (2) | 
READY (91) 
RPLY ($2) | | 


READ BYTE (MEMORY OR 1/0) 


PDBIN MAY BE STRETCHED BY CONTROLLING PRDY, PRDY IS 
EXAMINED AT $1 (WD) LEADING EDGE TIME DURING PDBIN. 


Figure 4-11. CPU Read Byte Timing 
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Eee |+— 500 NS TYP. 
en 


PSYNC | | 


<100 NS — <100 NS 


POBIN 
2200 NS 


STATUS & ADDR 


LOW BYTE HI BYTE 


>600 NS —»| = 


DATA READ 
2800 NS k-— 
PDBIN MAY BE STRETCHED BY CONTROLLING PRDY. 
PRDY 1S EXAMINED AT $1 (WD) LEADING EDGE 
TIME DURING PDBIN. 
2 (WD) 


SYNC (2) ee as a eee 
DIN ($2) es (ae 
READY (1) | | | | | | 
RPLY (2) | | | 


READY WORD (MEMORY) 


PDBIN MAY BE STRETCHED BY CONTROLLING PRDY, PRDY IS 
EXAMINED AT @1 (WD) LEADING EDGE TIME DURING PDBIN. 


Figure 4-12. CPU Read Word Timing 
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STATUS & ADOR 


2 (WD) [] P] [] a [] [] [ l] [] a [| 
SYNC (62) | | 
DOUT ($1) AS | | 

READY (01) | | 
RPLY ($2) | | 


WRITE BYTE (MEMORY OR 1/0) 


PSYNC MAY BE STRETCHED ONE OR MORE CYCLES DUE TO DOUT DELAY 
CAUSED BY MICROCODE. 


(2\ PWR MAY BE STRETCHED BY CONTROLLING PRDY. PRDY IS EXAMINED 
AT $1 (WD) LEADING EDGE TIME DURING PWR. 


Figure 4-13. CPU Write Byte Timing 
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100 NS —| —o| <100 NS 
awh reX "eX 
#100 NS —| F100 NS 
7100 NS 100 NS 
STATU 
S & ADDR | LOW BYTE HIGH BYTE 


DATA LOW BYTE HIGH BYTE 


$2 (WD) ] | [ ] [] a [] [] i i] [ ] [| a 
READY (91) | | | | a 
RPLY (2) | 


WRITE WORD (MEMORY) 


A\ PSYNC MAY BE STRETCHED ONE OR MORE CYCLES DUE TO DOUT DELAY 
CAUSED BY MICROCODE. 


(2\ PWR PWR MAY BE STRETCHED BY CONTROLLING PRDY. PRDY IS EXAMINED 
AT $1 (WD) LEADING EDGE TIME DURING PWR. 


Figure 4-14. CPU Write Word Timing 
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—+| |+— 500 NS TYP 


$, 18080) 


SYNC 


Ly 
<100 ns—e| | <100 NS 


POBIN 


2200 NS 


DATA READ/OUT ee! 


>600 NS — >100 NS 
—+| >100 NS 
&\ 


PWR 


STATUS & ADDR READ WRITE 


$2 (WD) 


SYNC (2) 


DIN (2) 


DOUT (91) | 
READY ($1) | | 
RPLY ($2) 


READ-WRITE-MODIFY-WRITE BYTE 


/\\ PSYNC MAY BE STRETCHED ONE OR MORE CYCLES DUE TO DOUT DELAY 
CAUSED BY MICROCODE. 


PDBIN AND PWR MAY BE STRETCHED BY CONTROLLING PRDY.PRDY IS 
EXAMINED AT $1 (WD) LEADING EDGE TIME DURING PDBIN OR PWR. 


Figure 4-15. CPU ReadeModify-Write Byte Timing 
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— }-—s00 NS TYP 


$, (8080) 


PSYNC » 


<100 NS —e | —| <100 NS —| - <100 NS — meas 


PDBIN 
>200 NS “i >400 NS 
DATA READ/OUT | LOW BYTE |X HIGH BYTE 


3800 NS mel AIOONS |! si00 Ns 
7100 NS —~~| 100 NS 


STATUS & ADOR LOW BYTE HIGH BYTE LOW BYTE HIGH BYTE 


2 (WD) 


SYNC (02) 


DIN (2) 


DOUT (91) | | | 
READY ($1) | | | | | | | 
RPLY (62) 


READ-MODIFY-WRITE WORD 


[\ PSYNC MAY BE STRETCHED ONE OR MORE CYCLES DUE TO DOUT DELAY 
CAUSED BY MICROCODE. 


(\ PDBIN AND PWR MAY BE STRETCHED BY CONTROLLING PRDY. PRDY IS 
EXAMINED AT $1 (WD) LEADING EDGE TIME DURING PDBIN OR PWR, 


Figure 4-16. CPU Read-Modify-Write Word Timing 
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4.2.4 INITIALIZATION AND STATUS. 

Initialization of the AM-100 occurs when the board set receives 
its initial power. Initial reset is accomplished by 
Power~On=Clear signal POC which goes low on initial power-up 

or for the PRESET signal that actuates the POC one-shot U22. 
Signal POC provides an output to the S-100 Bus and also clears 
register U10 in the reply logic. 


The logic that controls initialization of the CPU chip set 

is located on CPU1 and consists of two buffers: the status 
Byte Register buffer and the External Address Register Select 
buffer. 


The Status Byte buffer is used by the CPU chip set during 
power-up to determine the initialization sequence. There 
are eight bits in this register that function as defined 
in Table 4#7. The CPU chip set checks these bits as it 
proceeds through its initialization. 


Table 4-7. Status Byte Buffer Bits 


— NAME FUNCTION 


00 Used for AM-100 


Power-Up 


Option Jumpers 


Halt Option Not Used 
== 
[4 | frtorvupe Brabie | vectored Tnterrupe Grable 
es Coe 
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The external address register is used by the CPU to determine 
the base address of the bootstrap ROM. The base address is 
Six bits that are jumper selected by the header in U3. During 
the power-up sequence, these six bits are added to C000 to 
determine the bootstrap starting address. 


| Note 

See Section 2 of this manual for header U3 
wiring for the various peripherals used with 
the AM-100. 


The initialization process for the AM-100 must proceed through 
the sequence described below so that the CPU can access the 
bootstrap load program and begin executing. When the RESET 
pushbutton is pressed, the CPU sends out an external request 
to read the Status Register. This signal is ISR that accesses 
the eight bits of data as defined in Table 4-7. The CPU 

then checks each bit as described in Figure 4-17. When the 
CPU has checked the eight bits of the Status Register, signal 
EARS is asserted from the state code decoder and reads the 
base address from header U3. 


4.2.5 DATA ACCESS. 

Data is processed from the eight-bit S-100 bus system to 
the 16-bit CPU through the supporting logic on both CPU boards. 
The data bus is addressed and then the CPU performs either 
read or write operations. Read/Modify/Write is a combination 
of both in one sequence. 
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RESET 


READ 
EXTERNAL 


STATUS 


YES |; 
BIT 7 
HARD WIRED 


TO GND 


YES 
BIT 6 
HARD WIRED 


TO GND 


YES 
BIT 5 
HARD WIRED 


TO GND 


OUTPUT 


SYSTEM RESET 


STALL 
300 CYCLES 


CHECK 
BITS 0, 1 


READ EXTERNAL 
ADDRESS RGSTR 


DETERMINE 
BOOTSTRAP 
BASE ADDRESS 


Figure 4-17. 
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MICROINSTRUCTION ADDRESS 


0001 


0002 


0039 


0061 


0071 


0076 


0081 


0085 


0189 


AM-100 Power Up Sequence 


4.2.5.1 . ADDRESSING OPERATIONS. | | 

The CPU chip set utilizes a data bus that contains both the 
data and address multiplexed onto the same lines. When the 
CPU chip set has address data on the DAL, the SYNC signal goes 
true. This is applied to the clock input of the address 
latches U13, U14 and U25 to store the address data. Bits 
Al-A7 are applied directly to the S-100 bus through buffers, 
but the other bits require additional processing. 


There are two basic bus operations where addressing is con- 
cerned: memory and I/O. If we are performing memory read 
or write, then the lower byte contains AO-A7 and the upper 
byte contains A8-A15. When I/O operations are taking place, 
the CPU sends out Hex address FFXX. This generates signal 
IOSEL from the gate on U15 to distinguish between I/O and 
memory operations. Signal IOSEL switches the Data Select 
MUX to place AO-A7 on both the upper and lower bytes of the 
address bus. | 


Address line AO is generated by the sequencer logic on CPU2 

to provide for byte/word data operations. With word operations, 
two sequential addresses are fetched so AO is sequenced first 
with 0, then with 1. With byte operations, address line AO 

is unaffected by the sequencer. 


4.2.5.2 WRITE OPERATIONS. 

The DAL bus that processed the address data also contains 
the data for write operations. The buffered data lines are 
applied to the data select MUX on U17 and U18. This selects 
the appropriate byte for S-100 bus transfer to the selected 
memory or I/O controller. Signal HIBYTE selects either the 
upper byte or lower byte for transfer to the output bus of 
the S-100 Bus. | 


If a write byte operation is taking place, only eight bits 
of data are required. The address is first transmitted and 
then the lower byte of data is placed on both DALO-DAL7 and 
DAL8=DAL15. If a write word operation is taking place, a 
two-stage operation transmits the lower byte first to the 
eight S*#100 lines and then switches to the upper byte. 
Signal HIBYTE makes this selection. | 


4.2.5.3 READ OPERATIONS. 

The data input lines are buffered and are applied to the 
internal DAL bus on DAL8-DAL15. This input data is then 
stored in the Low Byte Input Storage register on U9 and U1O. 
For the read byte sequence, the S-100 bus signals request 
that the addressed memory or I/O port place its data on S-100 
bus lines DI0-DI7; signal DIN gates it on to the internal 
data bus to the lower byte storage. Signal READY from the 
Sequencer indicates that the CPU chip set is ready to accept 
the data so it is clocked into the Low Byte Input Storage 
register. The lower byte of data is on both DALO-DAL7 and 
DAL8-DAL15, and the CPU can read from either one. 


For the read word sequence, the lower byte is transmitted 
exactly like the read byte sequence. The sequencer then 
Starts another cycle and increments the LSB of the address 
to fetch the data from an odd address in memory. The data 
is applied to the input port as before and is gated to DAL8- 
DAL15. The Low Byte Input Storage register is not clocked 
this time so it still contains the low byte and the high 
byte is on DAL8-DAL15. The operation is terminated and the 
CPU chip set reads a 16-bit word from DALO-DALI15. 


4.2.6 DMA AND INTERRUPT OPERATIONS. 
The AM-100 provides seven levels of DMA and eight levels of 
interrupt capability. This data access processing is intes 


grated with the interrupt operations of the CPU chip set. 


4.2.6.1 CPU CHIP SET INTERRUPTS. 

The CPU chip set provides capability for four interrupts as. 
listed in Table 48. These interrupts are inputs to the 
control chip U28 on CPU1. 


Table 4-8. CPU Chip Set Interrupts 


INTERRUPT SIGNAL FUNCTION 7 
at a la 


_ 
[2 4 I2FF Enable for I0O and I1, con- 
trolled by user state codes. 


HALT Halt switch (not used). 


Interrupt I0 is the vectored interrupt and is the normal 


Non-vectored interrupt - real 


time clock. 


interrupt procedure. It is used by the peripheral controllers 
to signal the CPU when they have finished a task. Signal 

INTFF provides the IO input. from a signal generated on CPU2 
When any of the eight vectored interrupts have been asserted. 
This signal is generated by decoder U29, inverted, and stored 
in a D flip-flop on U10. Interrupt I1 is the non-vectored 
interrupt and the real time clock signal RTCFF supplies this 
input. Interrupt I2 is an enable for I0 and I1 and is supplied 
by the user state codes. This is generated by flip-flop U18 

on CPU2 that is preset by SC4 and cleared by SC5. Interrupt 

13 is a halt switch input that is not implemented on the AM-100. 


When a non-vectored interrupt is received by the CPU chip set 
(real time clock), it checks the contents of the status regis- 
ter to examine bit 7. This is the power fail bit which is not 
implemented in the S-100 bus structure so it is wired to ground. 
The CPU then determines that bit 7 is false and then fetches 


the program counter address from Location 2A. 


4.2.6.2 VECTORED INTERRUPTS. 

When a vectored interrupt is received by the CPU chip set 
(I0), the resulting process is similar to a read instruction. 
When Vectored Interrupt is asserted, jumper wires on CPU2 
connect it to any of the eight pads VI0O-VI7. This produces two 
outputs at the decoder: VINTRI-VINTR3 produce the interrupt 
code and the other output from pin 14 is asserted any time 
there is an input to the decoder. This produces INTFF which 
1S applied to CPU interrupt I0. At the same time, VINTRI1- 
VINTR3 are sent to CPU1 to the interrupt storage register Ul 
where they are clocked in by IACK. When Data In (DIN) is 
received from the CPU, IDIN is asserted which applies VINTRI- 
VINTR3 to the data bus DAL1-DAL3. The CPU then reads the 
interrupts from the bus. 


4.2.6.3 DMA OPERATIONS. 

The AM«100 provides seven levels of DMA capability. Levels 
VIO-VI6 are jumper selectable and level 7 is wired directly 
to PHOLD. 


The other DMA inputs are jumper selectable and provide corres- 
ponding DMAGRANT (DMAGRO-DMAGR6) outputs to the S-100 Bus. 

A DMAG output (DMARCVD) is generated one clock cycle before 
the selected DMAGRANT to signal all the DMA boards that a 

new DMA grant is about to be issued. No DMA device should 
issue a DMA request during the time DMARCVD is asserted. 
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4.3 CPU MICROPROCESSOR CHIP SET DESCRIPTION. 

The Western Digital MCP1600 microprocessor is an 8-bit micro- 
programmable computer implemented with 3 MOS/LSI chips using 
UDC's N-channel silicon gate process. The chip set consists 
of the CP1611B Data chip, the CP1621B Control Chip, and the 
CP1631B microinstruction ROM (MICROM) chip. 


These chips are interconnected by the 22 bit Microinstruction 
Bus (MIB) which provides bi-directional communication between 
the chips for addresses and instructions. A Data Access Bus 
provides a 16 bit port for communicating with other system 
components such as memory and I/O. 


The list below describes the pertinent aspects of the set: 


- 8-bit Internal Organization 

- 16-bit Data Access Port to Memory and I/O 

- 26 Registers 

- Extensive Microinstruction Set Including Decimal 
Operations 

- Single and Double Byte Operations 

- Micro and Macro Level Condition Flags 

- 512 Word x 22-bit Control ROM 

- Control ROM Expandable to 2048 words 

- Micro Level Subroutine Capability 

- Programmable Translation Array for Macroinstruction 
Interpretation 

- Four External Interrupts and Three Internal Interrupts 

- External Instruction Set 

- Power Supplies +12V, +5V, and -5V 

- TTL Compatible 3 State Interface 


Figure 4-18 describes the interconnection of the required 


components of the MCP 1600 microprocessor set. The DATA CHIP, 


(CP1611B) contains the arithmetic logic unit, the microinstruc- 


tions decode and the register file. Additionally, it contains 


paths to control the operation of the processor. 


The CONTROL CHIP (CP1621B) contains the program translation 
array, portions of the control circuitry to control operation 
of the processor set, the microinstruction counter and the I/O 
control system. 


The MICROM CHIP (CP1631B) contains the microinstruction ROM, 

The MP1600 microprocessor set may be expanded up to four MICROMs 
giving the user a total of 2,048 22 bit microinstructions. In 
addition to the three parts comprising the Microprocessor Set, 
twelve other available standard TTL parts are required. These 


parts serve to: 


- Generate the clocks 
~ Latch and gate input signals 
- Latch and gate output signals 
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Figure 4-18. MCP1600 Microprocessor Block Diagram 
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The three chips that make up the MP1600 microprocessor set 
are contained in standard 40-pin DIPS with pin assignments 
as listed in Tables 4-9, 4-10, and 4-11. 


Table 4-9. Data Chip (CP1611B) Pin Assignments 


PIN | PIN | PIN PIN 
NO. | SIGNAL NO. | SIGNAL NO. | SIGNAL [| NO. | SIGNAL 
21} 62 31 


Oo PON KN TH FP W NH FR 


pnd 
on) 


Table 4-10. Control Chip (CP1621B) Pin Assignments 


PIN | PIN 
SIGNAL | NO. | SIGNAL SIGNAL | NO. | SIGNAL 


p3 

VBB 

13 

i2 

Il 

Ip 
MIB17 
BUSY 
COMPUTE 
RESET 


WO WAN DT PW NY FF 


-_ 
an) 


Table 4-11. Microm Chip (CP1631B) Pin Assignments 


SIGNAL 


4.3.1 SYSTEM COMPONENTS. 

The main functional components of the CPU microprocessor are 
physically partitioned into three kinds of devices. The logical 
partitioning of the system, however, encompasses five areas as 
follows: | | 


1. Processing and Data Handling. This is generally 
handled on the CP1611B Data Chip. | 


2. Next Instruction Address Generation. This is gener- 
ally handied on the CP1621B Control Chip. 


3. Microinstruction Storage. These are contained on 


one or more CP1631B Microinstruction ROMs. 


4. Microinstruction Bus. This bus connects the three 


types of devices together and provides a path for 
the microinstructions to flow from the microinstruction 
ROM to both the Control and the Data Chip. 


5. Data Access Bus. This bus provides access from the 


MCP1600 microprocessor set to the outside world. 

Lines comprising this data access bus come from all 
three of the chip types. Lines containing the address 
and data come from the Data Chip, control lines 
defining the state of the data access come from the 
Control Chip and user programmable control lines come 


from the Microinstruction ROM. 


The MCP 1600 operates on a four phase clock system. While 
there are some variations, the general use of each phase period 
oe | 

- fl Instruction Access 

- $2 Data Access 

- 3 Execution 

- §4 Data Update 


4.3.1.1 REGISTERS. 
The various registers in the CPU microprocessor are described 


in the following paragraphs. 


Register File. The Register File consists of 26, 8 bit regis- 
ters which provide RAM data storage for the MCP1600 processor 
set. The register file has 2 output ports and 1 input port. 
Fourteen of the registers of the file can be directly addressed 
by the A and/or B register designators of a microinstruction. 
Additionally, the 16 top-most registers of the register file 
may be considered as register pairs and can be addressed by the 
G register to permit operation on full words of data. The 
Register File is on the Data Chip. 


The A and the B output ports of the register file feed into 
the ALU. 


G Register. The G register is a pointer register on the Data 
Chip that describes the currently accessed linked consecutive 
pair of registers in the register file. Note that, when the 

G register is being used, access to the register file is from 
the top down. This is opposed to the access to the register 
file when only the A and B fields are being used as designators; 


in which case,it is from the bottom up. This register is loaded 


by IW and LGL instructions. "Input Word" instruction loads 
the G Register from the DAL bus as specified by the "b" field 
of the instruction. "Load G Low' instruction loads the G 


Register Ra. 


The first (or lowest) 14 registers of the Register File are 
addressable only from the MIR register. The top 12 registers 
are addressable only from the G Register. The middle 4 regis- 
ters are addressable from either the G or the MIR registers. 
Figure 4-19 describes the addressing conventions of this file. 
It is helpful to note that if the a or b fields of the MIR 


are 1 or 0, then this enables G Register addressing. 
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Some Examples 


Assume G = 4, a = 0, b = B 
Then one operand (A Port) will be from G'8' 
The other operand (B Port) will be from R'B' 


Assume G = 0, a=7, b=1 
Then one operand (A Port) will be from R'7! 
The other operand (B Port) will be from G'1' 


Assume G = b, a=l1, b= 0 
Then one operand (A Port) will be from G'D! 
The other operand (B Port) will be from R'D! 


Assume G = 3, a= 6, b=A 
Then one operand (A Port) will be from R'6'! 
The other operand (B Port) will be from R'A' 


Assume G= 5, a= 0, b=1 


Then one operand (A Port) will be from G'5'! 
The other operand (B Port) will be from G'6! 
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REGISTER FILE ADDRESSING MODES 


Bottom 


0 0 
a lorb 4 a Cc F 
and or or 


FA Port { 


Figure 4-19. Register File 


ALU Status Bits. The ALU provides 4 status bit outputs which 
reflect the result of each 8 bit output which in turn reflects 
the result of each 8 bit operation. The ZB and NB bits are 
updated after every ALU operation. C4 and C8 are updated only 
during Arithmetic or Shift operations. These bits may be tested 
by Jump, but their primary function is to pass result data from 
the first cycle of a word instruction to the second cycle. 

The available status bits are: 


ZB: Set if the result of a Byte or Word operation is 
zero; cleared otherwise. 


NB: Set if the high-order bit of a Byte or Word operation 
is a one; cleared otherwise (except for SRW and SRWC). 
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Ca: 


C8: 


Set if Carry Out of Position 3 is a one; cleared 
otherwise. Updated only on Arithmetic operations. 
This status bit is used mainly for decimal arithmetic — 


corrections. 


Set if Carry Out of Position 7 is a one; cleared 
otherwise. (Note that this status bit is not set 
to borrow for subtract as is the case with the C 
Flag.) Also set if the shifted off bit of a Shift 


operation is a one; cleared otherwise. 


Condition Flags. The Condition Flags consist of 4 latches 


which can reflect the status of the previous ALU results. The 


updating of these flags can be selectively enabled or disabled 


at the discretion of the microprogrammer. The condition flags 


are updated with odd-numbered instruction opcodes in the range 


of 8@-EF. 


Z Flag: Set if the result of a Byte or Word operation 


is zero, cleared otherwise. 


N Flag: Set if the high-order bit of the result of Byte 


or Word operation (except for SRW and SRWC) 

is a one; cleared otherwise. (Note that this 
is the complement of the sign of the result if 
overflow occurs.) 


C Flag: Monitors the carry, borrow and shifted off bits 


as follows: 

Add and Increment: Set if there is a carry from 
the most significant bit of the 
Byte or Word result; cleared 
otherwise. 
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Subtract and 
Decrement: Set if there is a borrow 
(complement of carry) from the 
most significant bit of the 
Byte or Word result; cleared 


Otherwise. 


Shift: Set if the bit shifted off ina 
left or right shift is a one; 


Cleared otherwise. 


The C Flag is not affected for operations (other 
than those listed above) even if the other flags 


are updated. 


V Flag: Set if there is an arithmetic overflow on Arithmetic 

operations, cleared if there is no overflow and 

on Non-arithmetic operations. On Add operations, 
overflow occurs when the sign of the two operands 

are the same and the sign of the result is different. 
On Subtract. operations, overflow occurs when the 
Signs of the two operands are different and the sign 
of the result is different from the operand in Ra 
(V=C7 ® C8). 


The format of the ALU status and flag register word is shown 
below: 
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MIR Register. The 16 bit MIR register holds the least signifi-e 
cant 16 bits of the 22 bit microinstruction currently being 
executed. The MIR register is loaded every @1 unless the 
currently executing microinstruction is of the 2 cycle variety. 


In this case,the register is not clocked on the second occurrence 
of 91. 


4.3.1.2 INSTRUCTION ADDRESS GENERATION. 
This paragraph describes the registers and arrays used in 


generating the next microinstruction address. 


Location Counter Register. The Location Counter (LC) is an 

11 bit register which holds the address of the next micro- 
instruction to be accessed. Under normal conditions, the LC 
is incremented by one after each access of a microinstruction. 
The LC can be altered by other than one through execution of 
a Jump instruction or a Return from Sub-routine (RFS) instruc- 
tion or by the invocation of a PTA translation. 


Return Register. The Return Register (RR) holds an 11 bit 
address and permits a subroutine depth of one in the micro- 
program. When a subroutine jump is indicated (MIB 16 = 1), 
the return register stores the incremented contents of the 
LC. Contents of the return register can be transferred to 
the LC under the control of a RFS - (Return From Subroutine). 


Translation State Register. The Translation Register (TR) is 

a 16 bit register which holds the data presently being input to 
the PTA. Data on the Microinstruction Bus (MIB) is used to 
load the Translation Register. Note that only the upper or 
lower half of the Translation Register can be fed into Array 3 
at one time. 
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Translation Arrays. There are four arrays on the control chip 
that control the generation of the next microinstruction 
address. They generate new inputs into the LC register, as 

a function of the LC register contents, the contents of the 
translation register, interrupts, and other miscellaneous 
inputs. The detailed operation of these arrays is discussed 
in Section 4.3.3, PROGRAMMABLE TRANSLATION ARRAY (PTA). 


4.3.1.3 MICROINSTRUCTION BUS. 

The Microinstruction Bus serves to interconnect the three 
required parts of the MCP1600 Microprocessor set. The bus 
is organized into 4 distinct sections. 

MIBOO - MIB15 carry proper microinstruction data from the 
microinstruction ROM chip to both the control chip and the 
data chip. These lines may also carry data between the data 
chip and the control chip under certain conditions. 


MIB 16 controls the subroutine jump operation. When MIB16 
is set on a jump instruction, it causes the incremented con- 
tents of the LC register to be placed into the Return Register. 


MIB17, if set, causes the PTA on the Control Chip to perform a 
Read Next Instruction translation. 


MIB18 = MIB21 are TTL level outputs that can be programmed by 
the user as his needs dictate. They are not used by the MCP1600 
Microprocessor set to control its operations. They are pro- 
vided for the convenience of the user in order that he may 
interface to the MIB bus or control devices directly from the 


microprogram level. 


4.3.1.4 DATA ACCESS BUS. 


The data access consists of three sections: 


DALOO - DAL15 carry address and data between the data chip 
and the outside world. 


Outside Control Lines. There are five TTL level Outgoing Cone 
trol Lines that inform the outside world of the present state 
of the MCP1600 set. These signals include Sync, Input Instruce- 


tion, Output Instruction, Wait and Interrupt Acknowledge. 


Incoming Control Lines. There are 8 TTL level Incoming Control 
Lines. These incoming control lines inform the MCP1600 Micro- 
processor set of the state of affairs in the outside world. 
There are four interrupt lines, a Compute line, a Reset line, 

a Reply line and a Busy line. | 


With these lines, the MCP1600 can control a wide variety of 
peripheral devices. © 


4.3.1.5 MICROINSTRUCTION STORAGE. 

The microinstruction ROM (MICROM) is a 512 x 22-bit word, 

high speed ROM which stores the instructions of the micro- 
program. The transfer of addresses into the chip and the 
microinstruction out of the chip are performed over the MIB. 
Address is received from push-pull drivers in the Control Chip 
on $2. The decoding takes place on $3. On $4 the selected 
microinstruction is internally accessed and the MIB is pres 
charged. The accessed microinstruction is placed on MIB15- 
MIB@ for transfer to the Data Chip and Control Chip during @1. 


4.3.2 CPU OPERATIONS. 
This section describes the internal workings of the Data Chip, 
the CPU of the MCP1600 system. There are two important and 


distinct partitions to the processor. The first partition, 
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called the Data Chip, provides classical stored program pro- 
cessing. The Data Chip consists of: 


eA register file 

eAn arithmetic logic unit (ALU) 

eA Microinstruction register 

eA register file address decoder 

eA control signal generation function 
eCondition flags 

eJump decoding 


eInput/Output gating 


The data chip is responsible for data manipulation as a result 


of instruction execution. 


The second partition, the Control Chip, generates address data 
that directs the accessing of the next microinstruction to be 
executed. This address generation mechanism provides the MCP1600 
with its unique emulation capabilities. While the Data Chip 

1s executing the presently fetched microinstruction, the 

Control Chip is performing a transformation upon the presently 
executing macroinstruction to determine the address from which 


to fetch the next microinstruction to be executed. 


The description of the processor proceeds by first outlining 
the operation of the Data Chip (CPU) and then in the following 
section outlining the operation of the Control Chip. it 1s 
important to note that the two chips are not synchronized 
except by a common clock, and the fact that the contents of 
the MI register on the Control Chip and the contents of the 
MIR register on the Data Chip are the same. Very few control 


lines are passed between the Data Chip and the Control Chip. 
4.3.2.1 CPU SEQUENCING. 


First assume that the machine has been properly reset and has 


just entered the compute mode. The Control Chip causes a 
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microinstruction to be fetched from the MICROM to be placed 
on the MIB bus. (See Figure 4-20.) Assuming that the clock 
is now on the leading edge of $1, the contents of the MIB 
bus are gated into the MIR register on the Data Chip and the 
MI register on the Control Chip. 


At the end of $1 (trailing edge of the clock), the contents 
of the MIR register have settled. The contents on the MIR 
register are held fixed until the next occurrence of §1 (four 
phase times). 


At the beginning of 92, the contents of the MIR register are 
presented to the various different functions of the CPU. The 
A and B fields are presented to the address decoder, as is the 
G register. The contents of the MIR register's C field and 

OP field are presented to the master control function of the 
Data Chip. During #2 and $3, the master control function 
decodes the C field and generates signals which control the 
gating of data to the various functions of the Data Chip. 

In $2, the address decoder is interpreting the contents of 

A field and the B field and accessing the appropriate register 
in the register file. Also during 92, the condition codes | 
reflecting the result of the last ALU operation become valid. 
They are presented to the FLAGS register which retains them 
for examination on the next occurrence of $4. Figure 4-21 
illustrates $2 data paths. 


Phase 3 is the register access phase. During §3, data is 
presented to the ALU by the A and the B output ports of the 
register file. Data may also be presented to the ALU B port 
by means of the literal path from the MIR register. Note the 
literal path (whose contents are the A and B field of the MIR) 
bypasses the address decoding logic and the register file. 
Also during $3, the contents of the A and B register file 
output ports may be presented to the Data Access on line DALOO 
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-DALI5. During this phase time, the contents of the register 
file A port may be presented to the flag register. Finally, 
during this phase time, the contents of the register files 

A and B ports may be presented to the gating which controls 
access to the MIB bus. Figure 4#22 illustrates $3 data paths. 


During #4, the output of the ALU becomes valid. Input to the 
ALU may occur from the data bus in #4. That is, data presented 
on lines DALOO=-DAL15 may be presented to the gating structure 
which controls the output of the ALU. Finally, during 94, 

the data available from the Data Access may be presented to 

the gating structure that controls access to the MIB bus. 
Figure 4°23 illustrates the $4 data paths. Note that, during 
#4, the jump control takes place. If the jump decoder indicates 
that all the proper jump conditions are met and if JXX is 
asserted, then MIB15 will cause the Control Chip to effect 

a jump on the next clock cycle. | 


As the next $1 clock occurs to start the next cycle of the 
instruction/execution, the data that was presented to the gating 
structure that controls access to the A input port of the 
register file is gated or not gated, depending upon a signal 
from the Master Control, into the register file. Figure 4-24 
illustrates this path. If the instruction contained in the 

MIR register is one that requires only one clock cycle for 
execution, then a new instruction is fetched from the MICROM 
according to the address generated by the Control Chip and 
execution begins as in Figure 4-20. 


If however, the instruction requires two cycles for execution, 
things proceed differently. At the beginning of §1 of the 
second cycle, the contents of the MIR are preserved and no new 
data is gated in. The low order bits of both the 'A' and 'B! 
fields are complemented to access adjacent slots in the register 
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Figure 4-20. $1 Data Paths 
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Figure 4-21. $2 Data Paths 
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Figure 4-22. $3 Data Paths 
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Figure 4-24. $4 Data Paths Second Cycle 
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02, 03 


file to those previously addressed in the first cycle. Also 
during this phase, the CPU may output data to the MIB bus. 
Figure 4-24 illustrates this path. 


Other than these exceptions, two cycle instructions proceed 


as do one cycle instructions. 


4.3.2.2 CONTROL LINES. 

During @2 and $3, the Master Control function is decoding the 
new contents of the MIR register in order to generate signals 
to control the data transfers described above. These control 
Signals are generated on the basis of the contents of the C 

and OP fields of the MIR register. All of the control lines 
generated by the Master Control function are not described here 
because some of them serve timing and sequencing functions that 
are not necessary to the understanding of the CPU operation 

and how it affects the Data Access and Microinstruction Bus. 
Several are described in detail in the following paragraphs 

and in Figure 4- 25. | 


Register Load. This control line determines whether or not 
the output of the ALU will be gated back into the register 
file input port. It is invoked by register to register format 


instructions. 


Load Flags. This line controls whether or not the output of 
the FLAGS register will be gated into the register file input 
port. It is generated by the Load Flags and Copy Flags 


instruction. 


Load Hi Byte. This control line determines whether or not the 
contents of the DALO8-15 will be gated into the register file 
input port. This line is controlled primarily by the Input 


Class of instructions. 


4-75 


LITERAL DATA 


LOAD LIT 


B PORT OUTPUT ALU OUTPUT 
MIBOO-07 | 
| s MODIFY LO 
A PORT OUTPUT 
Chae LOAD TR LOAD LIT 
MiBOS-1 7 REGISTER LOAD ALU OUTPUT - 
LOAD FLAGS FLAGS OUTPUT - 
é = DAL@8.15 = 
E | LOAD HIBYTE 
@ 
F , f° 
| LOAD LopYTE —CaLee? 
DALO@-07 
| | FO7 
3( LOAD TR A PORT INPUT : 
: DALO8-15 
MODIFY HI 
x< 
~ 


B PORT OUTPUT 


CONTROL LINES 


MASTER 
CONTROL 


WAIT DAL@S8.15 


DOUBLE/SINGLE 


DAL@O@7 


Figure 4-25. Major Control Lines 
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Load Lo Byte. This control line determines whether the con- 
tents of DAL-07 will be gated into the register file input 
port. It is generated by input class instructions. Note that 
this signal and preceeding signal are generated by the speci- 
fication in the B field of the appropriate input instruction. 
Note also that one can input the low order byte, the hi order 
byte, or both bytes. This latter case is an input Word 
Instruction. | 


Modify Lo. This control line is invoked by the Modify instruc- 
tion and causes the output of the A register file port to be 
gated on to the low order 7 bits of the microinstruction bus. 
This control line is also invoked by the Load Translation 


Register instruction. 


Modify Hi. This control line is the high order analog of the 


previously described control line. 


JXX. This control line is invoked by the jump instruction. It 
is made hi during the first phase four of the jump instruction, 
1f the jump instructions have been met. It causes the contents 
of the MI register on the control chip to be placed into the 


LC register. 


Load LIT. This instruction controls the multiplexer which 
selects the B input to the ALU. The ALU B input port may be 
fed from either the literal field of the MIR register or the 

B port output of the register file. This control signal is 
set by the literal class of instructions and causes the B input 
to the ALU to be selected from the literal path. 


Double/Single. This control line is generated by the Master 
Control for use by itself. It is invoked by instructions that 


require two cycles for execution. In the main, it controls 


whether or not a new instruction is gated into the MIR 
register at the next occurrence of §1. 


Load TR. This control line is invoked by the Input Word 
instruction if either bits 4 or 5 of the B field are set. 
These bits being set will cause the data on the Data Access 
to be placed into the translation register on the Control 
Chip. It is in this fashion that new macroinstructions are 


fetched from the user memory for decoding. 


4.3.3 PROGRAMMABLE TRANSLATION ARRAY (PTA). 

This section describes the operation of the MCP1600 Micro- 
processor set's most unique feature, the Programmable Trans- 
lation Array. The Programmable Translation array serves to 
generate new microinstruction fetch addresses as a function of 
several parameters. These parameters are those which are 
normally considered during the decoding of a macroinstruction. 
While the Programmable Translation Array was designed speci- 
fically to eliminate most of the overhead of macroinstruction 
translation, it is useful for other purposes. For example, 

a data driven processor could determine the next operation 

to be performed on a data structure as a function of the 


present data and the present operation. 


Briefly, the Programmable Translation Array consists of eight 


elements. They are: 


eLocation Counter 

eArray 1 

eArray 2 

eArray 3 

eTranslation Register 
eArray 4 

eTranslation State Register 


eReturn Register 


These elements give the capability of calculating micro- 
instruction addresses other than sequentially, or as specified 
by a jump instruction. Figure 4-26 depicts their interconnec- 
tion. The mapping (or new Location Counter value) that the 
PTA generates, when invoked, is a function of the value of the 
Location Counter, the contents of the Translation Register, 
the interrupts, and the state of the RNI line. 


4.3.3.1 PROGRAMMABLE TRANSLATION ARRAY COMPONENTS. 
This Section describes the components of the Programmable 


Translation Array and their functions. 


Location Counter. It is the function of the Location Counter 
to hold the address of the next microinstruction. The Location 
Counter is 11 bits wide and has outputs to MIBOO=-MIB10 and to 
Array No. 1. It has inputs from the Master Control function, 
Array No. 4 and the Return Register. There is also an input 


to the Location Counter from an incrementer. 


Array No. 1. Array No. 1 is an 88 element array with 23 inputs. 
There are 11 true inputs and 11 complemented inputs from the 
Location Counter and the RNI bit (MIB17). Figure 4-27 illus- 
trates the organization of Array No. 1. Figure 4-28 illustrates 
the concept, as opposed to implementation of a typical gate, 

one of 88, that make up Array No. 1. The outputs of these gates 
make up the bulk of the inputs of Array No. 2. 


The purpose of Array No. 1 is to perform a selection function. 
When the inputs to Array No. 1 match one (or more) of the word 
values (addresses), the output associated with that word is 
asserted. This array is programmed with 6 hexidecimal digits 
as shown in Figure 4-29. Transistors are placed in the array 
for 1 bits in the data specification. To program a group of 


addresses, the bits of the address to be left out are specified 


15 


o 
a 
2 


TRANSLATION CODE 


LRA 


PTA 10} 


SET/RESET 14-6 


LOINC 


LOJA, LOJB 


MASTER CONTROL 
02 and @3 


Figure 4-26. PTA Component Interconnections 
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Figure 4-27. Array No. 1 Organization 
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Figure 4-28. Typical Gate - Array No. 1 


as § bits for-the true and complement address inputs. This 
produces a 'DON'T CARE' effect for those bits and the result 


will always be a match. This lets the user match on modulo 
address. | 


The RNI serves to inhibit the output of Array No. 1. The 
reason for this is described later. 


(0 | wcaopress [eo] TCADDRESS 


2322 121110 0 


Example: 
Address = X’ 5F8’ 


Array #1 Data Word = X’ 5F8A07’ 


! 


Figure 4-29. Array No. 1 Data Specification 


Array No. 2. Array No. 2 is an ORed array whose outputs are 
negated. The array has 89 inputs, 88 from Array No. 1 and 
one from MIB17, the RNI line. The seven outputs from Array 
No. 2 represent a translation state code and become inputs 
into Array No. 3. 


Figure 4-30 illustrates the organization of Array No. 2. 
Figure 4-31 illustrates in some detail, the conceptual structure 
of the gate and interconnect structure of Array No. 2. The 
small circles present where the lines would normally cross 
represent connections that can or cannot be made. It is via 
the making or not making of the connections with transistors 
that this array is programmed. 
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Figure 4-30. Array No. 2 Organization OUTPUTS 
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Array #2 is driven by the inputs from Array #1. When one or more outputs of Array #1 are asserted, 
Array #2 will make the corresponding word available as its outputs. 


STATE CODE OUTPUTS 


The purpose of Arrays #1 and #2 is to provide a mapping between the present value of the Location 
Counter and a preselected set of translation state codes. : 


Figure 4#31. Array No. 2 Gate and Interconnect Structure 
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Due to electrical considerations, there are restrictions placed 
on the configuration of Array No. 2. Normally this array is 
programmed in a 4 of 7 code (4 of 7 outputs may be selected 

to be high, the other 3 must be low), or more ideally, to 
reduce capacitive loading, a 5 of 7 code. The tables 4-12 and 
4-13 describe the various state code outputs available in 

both the 4 of 7 and the 5 of 7 schemes. 


Table 4-12. Translation Table 4-13. Translation 
State Code Outputs--4 of 7 State Code Outputs--5 of 7 


The outputs of Array No. 2 represent some of the inputs to 
Array No. 3. 


The RNI line (MIB17) deserves mention at this point. It is | 
the purpose of the RNI line to force a particular user defined | 
State code from the mapping represented by Arrays No. 1 and 

No. 2. This state code will be independent of the contents 

of the Location Counter. 


Accordingly, RNI inhibits the outputs of Array No. 1 and 
invokes that state code selected by the user in Array No. 2 
and makes it present at the output of Array No. 2. 


The programming of Array No. 2 is illustrated in Figure 4-32, 
Transistors are put in the arrays for zero bits as per the > 
data specifications. 


ol 
Code 
0 


76 
Example: X’57’ 


Figure 4-32. Data Specification 


Array No. 3. Array No. 3 is a NANDed array, and has 42 inputs. 
In contrast to Arrays No. 1 and No. 2, the inputs come from 

a variety of sources. The inputs to this array constitute a 
direct interface to the real world at the macromachine level, 
as one of the inputs is the translation register. The inputs 
to Array No. 3 are: | 


‘Seven from Array No. 2. (Translation Code) 

‘Sixteen from the Translation register. Eight are true 
data and eight are complemented data. 

*Fourteen inputs from the interrupt latches. Again, both 
true and complemented data are present. | 

*Two from the translation state register. Again, both 
true and complemented data are used. 

‘One input, called the Q signal, not generally usable. 


It is worth noting, that while there are 42 inputs in Array 
No. 3, they are not all present at the same time. The array 
is broken into two partitions. The first partition consists 
of words 0 through 15, and has as its inputs, the 14 bits from 
the interrupt latches. The second partition of the array, 
words 16 through 99 have in the same slots the 16 bits of 
inputs from the Translation Register. 


The Figure 4-33 illustrates the structure of the first parti- 
tion of the array. Figure 4-34 illustrates the second parti- 
tion of the array. Figure 4-35 shows a conceptual picture 


of a typical gate in the array. 
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Figure 4-33. Array No. 3 Interrupt Organization 
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Figure 4-34, Array No. 3 Translation Register Organization 
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Array No. 3, being an ANDed array, will try 
figuration of its inputs against one of the 
If it finds a match, the output 
that word will be asserted. 


the array. 


Array No. 
digits. 


Translation 
Code 
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Interrupt 
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Translation 
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interrupt 
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Figure 4-35. 
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words. that make up 


associated with 


eight hexadecimal 


DON'T CAREs, which always result in matches, are 


created by placing both true and complemented bits to zero. 


Below is a data specification for the programming of Array 
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Array No. 4. Array No. 4 is a NORed array with 100 inputs which 
come from Array No. 3. The outputs generated by Array No. 4 
include address data to be fed into the Location Counter, data 
to be fed into the Translation State Register, and three control 
lines. Two control lines determine whether the Location Counter 
will be loaded from the Return Register or the output of the 
translation array. The third control line determines whether 

or not the value presented to the Translation State Register 
will in fact be loaded into the Translation State Register. 
Figure 4-36 illustrates the organization of this array. Note 
that not all the outputs are complemented. The two control 
Signals LRA and LTA are true data. 


Array No. 4 will determine if any of its inputs are active. 
If they are, the word associated with the active input is placed 
on the output lines. | 


The array is programmed into terms of true data. Five hexa- 
decimal digits are used to program each word. Transistors are 
placed in the array for 1 bits in the data specification. More 
than one active AND gate in Array 3 causes the outputs to OR. 
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Figure 4-36. Array No. 4 Organization 


Translation State Register. The Translation State Register 
serves two functions. One is to determine whether the Hi or 
the Lo order byte of the Translation Register is to be selected 
for input to Array No. 3. The other is ta provide a four state 
feedback as an input of Array No. 3. The loading of the Trans- 
lation State Register is controlled by an output (LTSR) of 
Array No. 4. 


Translation Register. The Translation Register holds the data 
presently serving as input to the Programmable Translation Array. 
It receives its inputs from the Microinstruction Bus (MIBOO - 
MIB15) as a result of an LTR or IW instruction. Because of the 
fact that its output destination is 8 bits wide, only half of 


the Translation Register can be examined at any one time. The 


Translation State Register controls which half of the Translation 
Register is gated into the input of Array No. 3, its destination. 


It serves as a feedback term of information to the second half 
of the word. 


Bit 2 of the TSR controls the selection of translation input | 
from the TR. When this bit is a zero,the upper byte of the TR. 
is selected; when it is a one,the lower byte is selected. TSR2 
does not serve as an input to Array No. 3. 


4.3.3.2 PROGRAMMABLE TRANSLATION ARRAY OPERATIONS. 

This section describes the operation of the Programmable Trans- 
lation Array. The Programmable Translation Array operates 

as a loop. The beginning and end points of the loop can be 
considered as the Location Counter. 


This loop is completed within one machine cycle and the main 
components are: 


The Location Counter 

Arrays No. 1 and No. 2, which taken together perform a 
mapping of the Location Counter to a translation code. 
The translation register, which holds the macroinstruction 
undergoing the translation process. | | 
Arrays No. 3 and No. 4 which take the translation code 

and the macroinstruction presently undergoing translation 
and map them into an address. 


This newly generated address can then point to the beginning 


of a macroroutine to interpret the macroinstruction presently 
accessed. 


The operation of the Programmable Translation Array is a 


function of phase time clocks and begins at $1. During 91, 
the location counter is loaded with its new value. The new 


value can come from any one of four sources as follows: 
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From Array No. 4 of the Programmable Translation Array 
From the MI register 

From the incrementer 

From the Return Register 


Figure 4-37 assumes, for the purposes of instruction, that the 
Location Counter is loaded from the incrementer. Concurrently, 
with the loading of the Location Counter at §1, the Trans- 
lation Register is also being loaded if either a LTR or an 


IW instruction was executed. 


At the beginning of 62, (see Figure 4-38) the contents of the 
Location Counter are clocked out to the MIB bus (MIBOO-10) and 
to Array No. 1. Both the true and complemented forms of the 
Location Counter are input to Array No. 1. Also input is the 
RNI line. Array No. 1 takes the input data word and determines 
Whether or not it has a match. If it has a match, then the 
appropriate output is set at the end of 92. If there is no 
match, the translation proceeds no farther because no outputs 
are set. 


At the beginning of 63, (see Figure 4-39), Array No. 2 samples 
the outputs from Array No. 1 and determines whether any are 
active. If there is a match, then the translation code is 


generated and fed to Array No. 3, also during 93. 


During #3, the contents of the selected byte of the Translation 
Register are fed to Array No. 3 along with the contents of the 
interrupt register, the Translation State Register, and the Q 
bit. During the later portions of $3, Array No. 3 determines 
if there is a match and, if a match is found, at the end of §3 


an output is generated. 
This output is fed into Array No. 4 at the beginning of 94. 


(See Figure 4-40.) During @4, Array No. 4 determines whether 


there is an active input to it. If there is an active input, 
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the contents of the word associated with the input are sent out 


at the end of 04. The Array No. 4 word may or may not cause 
the Translation State Register to be loaded, and may or may not 
cause the Location Counter to be loaded at the next occurrence 
of #1. | 
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Figure 4-37. §1 Data Flow 
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Figure 4-38. 92 Data Flow 
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Figure 4-39. §3 Data Flow 


4-94 


TRANSLATION CODE 


MiB 16 


15 - 


M!B 00 


SET/RESET 14-6 


LOJA, LOJB 


RESET 2 
COMPUTE 


MASTER CONTROL 
@2 and 03 


Figure 4-40. @4 Data Flow 
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4.3.4 MICROINSTRUCTIONS. | 

This section contains descriptions of the microinstructions. 
With each description is a diagram showing the format of the 
instruction and its operation code given in hexadecimal. 

Above each diagram is the instruction mnemonic operation code, 
the argument needed by the assembler, the instruction, and 

the name of the instruction. Under each diagram is a descrip- 


tion of the command and its timing in clock cycles. 


While the formats presented here describe 16 bits of instruction 
word, be aware that the word is, in fact, 22 bits wide. The 
portion of the instruction described here controls the operation 


of the processor. ‘The other 6 bits are: 


ebits 16 and 17 are involved with control of the Location 
Counter. Bit 16 determines whether or not the contents 
of the Return Register will be loaded into the Location 
Counter. Bit 17 determines whether or not a Read Next 


Instruction translation will be invoked. 
These two options are available on all instructions. 


*bits 18 through 21 have nothing to do with control of the 
MCP1600 system. They are available for the user to program 


as TTL levels. These bits are available on all instructions. 


Instruction Types. All of the MCP1600 microinstructions are 
22 bits long. Of the 22 bits, the 16 least significant effect 
the operation of the CPU. The purposes of the other 6 bits 
are covered in either the Programmed Translation Array descrip- 


tion or the Micro Instruction Bus description. 


The instructions for the MCP1600 are divided into four classes 


as follows: 
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JUMP FORMAT 


por fm] Aeros 
0 


15 121110 


This format provides an 11-bit Control ROM address. It causes 
an unconditional jump to any location in the permissable MICROM 
address space by always asserting the jump control line (JXX 

on the Data Chip or MIB 15 on the Micro Instruction Bus). The 
unconditional jump instruction is the only one that utilizes 
this format. 


Unconditional jump instructions always take two clock cycles; 
one to decode the instruction, the second to load the Location 
Counter on the Control Chip. 


A special case of this format is the Return From Subroutine 


instruction, covered later. 


CONDITIONAL JUMP FORMAT 


15 1211 87 0 


This format provides a Jump address within a page. This instruc- 
tion is substantially the same as the Unconditional Jump format 
with the exception of the reduced address space. It is also 

a two cycle instruction with the jump decision (based upon 

the contents of the C Field) being made by the jump decode 

logic on the Data Chip during the first cycle. This decision 

is communicated to the Control Chip via MIB15 (JXX on the Data 
Chip). During the second cycle the jump is affected. 


LITERAL FORMAT 


cs 


15 1211 43 0 


A= 97] 


This format provides 8-bit literal data. The "a" field usually 
specifies a file register. These instructions invoke the 
"literal path" to fetch data around the register file for the 
'b' input to the ALU. All of these instructions execute in 


one clock cycle. 


REGISTER FORMAT 


15 87 43 0 


This format is by far the predominant one. In it, "b" and "a" 
are register file designators. Generally, depending upon the 


Operation, there can be two meanings to the register designators: 


SSS SSR EEE EES EE SPC} ETE PSS SEP 
"b'' (operation) Mart 
as, for instance, in a shift or move instruction 
lp aah (operation) watt Molt 


as, for instance, in an arithmetic instruction. 


"b" and "a'' can specify either a single byte data quantum or 

a word (double byte) data quantum. In this latter case, the 
designators usually point to the even addressed member of a 
register pair. While they may both point to an odd addressed 
pair, note carefully the instructions description for the effect. 


If the designators apply to a word data quantum, the instruction 
takes two cycles to execute. The following sections describe 
MCP1600 instructions by classes of function. See Table 4-14 

for the microinstruction set, Table 4-15 for a list of the micro- 
instructions, and Table 4-16 for a summary of microinstruction 
and status flags. 
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Table 4-14. Microinstruction Set 


[Symbols dT SSC Meaning ——SOSCSCSCSCSCSSSTCCCC‘(S 
is transferred to 
contents of location or register 
Logic Product (AND) 
Inclusive ‘‘or”’ 
Exclusive ‘‘or”’ 
Forms extended register Ry = LSB, Rx = MSB 
The register specified by the micro-instruction ‘‘a’’ field 


Designates no catagory 


The register specified by the micro-instruction ‘‘b’’ field 
Don’t care condition 

Flag cleared (set to @) 

Flag set 

Flag not affected 

Set according to function 
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Table Rae. Microinstructions 


i Nd 


to microm location specified by MIR11-0¢ 


a 
from SaBONTinES | 
conditional within microm page 
Jump if ZB True If ZB=1, (MIR@7-00)-(LC7-0) 
Jump if C8 False If C8=0, (MIR@7-00)-(LC7-) 
Jump if C8 True if C8B=1, (MIR@7-00)+(LC7-0) 
Jump if ICS False If ICS=@, (MIRW7-00)-(LC7-0) 
Jump if ICS True - If I\CS=1, (MIR@7-00)-(LC7-0) 
Jump if NB False If NB=0, (MIR@7-00)-(LC7-@) 
Jump if NB True If NB-1, (MIR@7-00)-(LC7-0) 
Jump if Z False If Z=0, (MIRO7-00)-(LC7-O) 
Jump if Z True If Z=1, (MIR@7-00)-(LC 7-0) 
Jump if C False If C=0, (MIR@7-00)-(LC7-0) 
Jump if C True If C=1, (MIR@7-00)+(LC 7-0) 
Jump if V False If V=0, (MIR@7-00)+(LC 7-0) 
Jump if V True If V=1, (MIR@7-00)-(LC7-@) 
Jump if N False If N=0, (MIR@7-00)-(LC7-@) 
Jump if N True If N=1, (MIR@7-0@)-(LC 7-0) 


Add Literal 
Compare Literal 


NO NO NN KR NN DN ANA AD A AD AD AO 


(Ra)-Literal. The 8 bit result of the 
literal is compared against Ra and 


(Ra)A Literal-(Ra) The 8 bit result 
of a logical product of Ra and the 
literal are coded into Ra. 


(Ra) A Literal The 8 bit result of the 
logical product of Ra and the literal 


And Literal =e 
Test Literal 
set condition Flags. The contents of 
Ra are unaffected. 


Load Literal Literal+(Ra). The 8 bit literal is 
loaded into Ra. 
Reset Interrupts The three software interrupts 14, 15, and 
16 are reset as indicated in the instruction 
b field. 
Set Interrupts The three software interrupts 14, 15, and 
are set as indicated in the instructions 
t field 
Copy Condition Flags Flagse(Ra) The four condition flags are 
four ALU status flags are loaded in Ra 
Load Condition Flags (Ra)+Flags. The contents of Ra are 
unconditionally and to the condition flags 
under control of the b field. 


transferred to the ALU status flags 
Reset TSR Leics RTSR 4 * 3 0-(TSR). The three TSR bits in the 
| control chip are reset. | 


Load G Low (Ra) 2-0 -(G). The three least significant 
bits of Ra are loaded into the G register. 

Conditionaily Increment If C8 is set, (Ra)=!I +(Ra) 

Byte | | 

Conditionally Decrement 77 If C8 is set, (Ra)-1 - (Ra) 

Byte 
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Table 4-15 (Cont.). Microinstructions 


Move Byte 80/81 (Rb)-(Ra). The 8 bit contents of Rb | 
are transferred to Ra. Rb is unaffected. _ 

Move Word 82/83 MW 2 (Rb)-(Ra). The 16 bit contents of Rb+! Rb 
are transferred to Ra+1:Ra. Rb+!l and Rb 
are unaffected. 

| Conditionally Move Byte 84/85 CMB (Rb)+(Ra), if C=!. The 8 bit contents of 

Rb are transferred to Ra if the carry flags 
is set from a previous operation. 

Conditionally Move Word | 86/87 (Rb)+(Ra), if C=!. The 16 bit contents of 


Rb=!: Rb are transferred into Ratl: Ra if 
the carry flag is set from a previous operation. 
Shift Left Byte with Carry} 88/89 SLBC (Rbm)-(Ram+!), (carry) +(Rad). The 8 

bit contents of Rb are shifted left one bit 
and loaded into Ra. The contents of the 
carry flag is inserted into the vacated low 
- - 
Shift Left Byte 8C/8D SLB 
Rb are shifted left one bit and loaded 
into Ra. 
Increment Byte by 1 90/9! ICBI | 1 (Rb)+I-(Ra). The 8 bit contents of Rb are 
incremented by one and the result is 
transferred to Ra. 
Increment Word by 1 92/93 ICWI (Rb)+1l-(Ra). The 16 bit contents of Rb+!:Rb 
are incremented by one and the result 
Increment Byte by 2 94/95 ICB2 | 


Shift Left Word with Carry (Rbm)-(Ram+l), (carry)-(Radé). The 16 
bit contents of Rb+I:Rb are shifted left 
one bit and loaded into Ra+!:Ra. The 
contents of the carry flag ts inserted into 
the vacated low position of Ra. 


(Rbm)+(Ram+!) The 8 bit contents of 


(Rb)+2+(Ra). The 8 bit contents of Rb are 
incremented by two and the result 
transferred to Ra. 

(Rb)+2+(Ra). The 16 bit contents of 
Rb+I:Rb are incremented by two and the 
result transferred to Ratl: Ra. 
(Rb)+!-Ra. The 8 bit contents of Rb are 
two's complemented _and transferred to Ra. 
(Rb)+!-Ra. The 16 bit contents of Rb+! 
Rb are two's complemented and transferred 
to Ratl:Ra. 

(Rb)-Ra. The 8 bit contents of Rb are one’s 
complemented and transferred to Ra. 
(Rb)-Ra. The 16 bit contents of Rb+!l: Rb 
are one’s complemented and transferred to 
Ratl: Ra. 

(Rb)+(Ra)+(Ra). The 8 bit contents of Rb 
are added to Ra and loaded into Ra. 
(Rb)+(Ra)+(Ra). The 16 bit contents of 
Rb+!:Rb are added to Ratl:Ra and loaded 
into Rat+l:Ra. 

(Rb)+(Ra)-(Ra), if C=!. The 8 bit contents 
of Rb are added to Ra and the result is 
transferred to Ra if the carry flag is set 
from a previous operation. 
(Rb)+(Ra)-(Ra), if C=!. The 16 bit contents 
of Rb+1:Rb are added to Rat!: Ra and 

the result is transferred to Ratl;Ra if 

the carry flag is set from a previous 
operation. 
(Rb)+(Ra)+C-(Ra). The 8 bit sum of the 
contents of Rb plus the carry flag are added 
to Ra and the result is transferred to Ra. 


position of Ra. 

transferred to Ratl: Ra. 
Increment Word by 2 96/97 1CW2 
| Twos Complement Byte 98/99 | 


— 

= 
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One’s Complement Word 
Add Byte AQ/AI 


NO 


z 


Add Byte with Carry AB/AQ ABC 
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Table 4-15 peamneet npclaiaecaeasincamaila 


Add Word with Carry: | AA/AB (Rb} (Ra)+C- (Ra). The 16 bit sum of the | 
contents of Rb+1.Rb plus the carry flag are 
added to Ra+1:Ra and the result is transferre: 

_ ; | | __ to Ra+1:Ra. | a 
Conditionally Add Digits] (Rb)3.9+(Ra)3.o*(Ra)3.9, if C4=0 
(Rb)7.4+(Ra)7->*(Ra)7.4, if C8=0 oe 
: The 4 least significant and/or 4 most significa. 
| bits of Rb are added to their corresponding 
bits in Ra if C4 or C8 and reset respectively 
from a previous operation. This allows 
AE/AF CAWI 
if the ICS code is set from a prior operation. 
This instruction allows address displacement 
| _ addition on Branch conditions. | | 
Subtract Byte on (Ra)-(Rb)+(Ra). The 8 bit contents of Rb 
are subtracted from Ra and the result 
_ loaded into Ra. 
Subtract Word inn (Ra)-(Rb)+(Ra). The 16 bit contents of 
: Rb+I:Rb are subtracted from Ratl: Ra and 
, | the results loaded into Rat!: Ra. | 
| Compare Byte B4/B5 CB (Ra)-(Rb). The 8 bit difference between 
the contents of Ra and Rb is used to set 
Compare Word B6/B7 CW | 2 | 
| the contents of Rat+!:Ra and Rb+!: Rb are 
used to set the status flags at all times 
and the condition flags if OP Code B7 is 
selected. Registers Rat+!:Ra and Rb+!:Rb 
| are not changed. _ 
(Ra)- (Rb)-C+(Ra). The difference of the 
8 bit contents of Rb subtracted from Ra 


decimal arithmetic corrections. 

the status flags at all times and the © 
Subtract Byte with Carry 

minus the contents of C flag is loaded 


~ Conditionally Add Word 
on Indirect Condition 
Status 


(Rb)+(Ra)+(Ra), if 1CS=!. The 16 bit 
contents of Rb+I: Rb are added to Rat: 
condition flags 1f OP code B5 is selected 
Registers Ra and Rb are not changed. 


Ra and the results transferred to Rat+!:Ra 
(Ra)-(Rb). The 16 bit difference between 


(Ra)-Rb)-C-(Ra). The difference of the 16 
bit contents of Rb+I:Rb subtracted 

from Rat!:Ra minus the contents of 

the C flag is loaded into Ratl:Ra. © 


Decrement Byte by | BC/BD (Rb)-1+Ra. The 8 bit contents of Rb 
minus one are loaded into Ra. 

Decrement Word by | BE/BF (Rb)-l+-Ra. The 16 bit contents of Rb+!: 

Rb minus one are loaded into Ratl:Ra. . 

And ae C@/CI a (Rb) A(Ra)+(Ra). The 8 bit logical product 
of Rb and Ra is loaded into Ra. 

And een C2/C3 (Rb)A (Ra)+(Ra). The 16 bit logical 

| product of Rb+!:Rb and Ratl: Ra is loaded 
into Ratt: Ra. | 

Test Byte C4/C5 (Rb)A(Ra). The 8 bit logical product of 
Rb and Ra sets the status flags at all 
times and the condition flags if OP code 
C5 is selected. Ra and Rb are unchanged. 

Test Word C6/C7 (Rb)A(Ra). The 16 bit logical product of 
Rb+!:Rb and Rat+l:Ra sets the status 
if OP code C7 is selected. Ra and Rb 
are unchanged. 

Or Byte C8/Cc9 (Rb) V(Ra)+(Ra). The 8 bit logical OR 
operation is performed between the con- 
tents of Ra and Rb and the result are 

transferred to Ra. 


Subtract Word with Carry 


flags at all times and the condition flags 
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Table 4-15 (Cont.). Microinstructions 


Or Word CA/CB OW 2 (Rb)V (Ra)+(Ra). The 16 bit logical 
| OR operation is performed between 
the contents of Ra+l:Ra and Rb+!: Rb 
and the results are transferred to 
Rat+!:Ra. 

Exclusive-Or Word CE/CF (Rb)¥(Ra)-Ra. The 16 bit logical exclu- 
sive OR operation is performed between 
and the result is transferred to Ra+l:Ra. 

~ And Complement Byte | D@/DI (Rb) A(Ra)-(Ra). The 8 bit logical pro- 
duct of the inverse of Rb and the con- 
tents of Ra is loaded into Ra. 
duct of the inverse of Rb+!l:Rb and the 
contents of Ratl:Ra is loaded into Ratl:Ra. 

Shift Right Byte with D8/D9 SRBC 

Carry contents of Rb are shifted right one bit 
and loaded into Ra. The carry flag is 

| Ra. 
Shift Right Word DA/DB SRWC 


Exclusive-Or Byte CC/CD XB (Rb)¥(Ra)-Ra. The 8 bit logical exclu- 
sive OR operation is performed between 
the contents of Rb and Ra and the result 
is transferred to Ra. 
the contents of Rb+!:Rb and Ratl: Ra 

And Complement Word iouak pp (Rb) A(Ra)-(Ra). The 16 bit logical pro- 
(Rbm+1) -(Ram), (carry)+(Ra7). The 8 bit 
inserted into the high order position of 

with Carry 


(Rbm+!)+(Ram), (carry)+(Ra15). The 16 
bit contents of Rb+!:Rb are shifted right 


of Rat. 

Input Byte EWE! 1 (min) (DAL)+(Ra). An 8 bit byte on the DAL is 
in this instruction selects read or read- 
to be input from the Dal lines. 

Input Status Byte E4/E5 ISB (DAL)+(Ra). The 8 bit byte from the DAL 
or busy signal. 
registers Rb:Ra are ORed with the contents 
micro-instruction. This instruction can be 


one bit and loaded into Rat+l:Ra. The carry 
flag is inserted into the high order position 
Shift Right Byte oo 3 re eee | The 8 bit contents of Rb 
are shifted re eee | one bit and loaded into Ra. 
Shift Right Word taal (Rbm+!)+(Ram). The 16 bit contents of 
Rb+I:Rb are shifted right one bit and loaded 
into Ratl:Ra. 
loaded into the specified Ra. The b field 
modify - Write operation and selects upper 
(Bit 15-8) or lower (Bits 7-0) as the byte 
Input Word E2/E3 2 (min) (DAL)+(Ra). The 16 bit word contained 
on the DAL is loaded into Ra+l:Ra. The 
b field in this instruction selects read or 
read-modify-write operation, selectively 
updates the G register, and selectively sets 
the ICS bit. 
line, as specified by the b fold is input to 
register Ra, regardless of the state of reply 
Input Status Word E6/E7 (DAL)+(Ra). The 16 bit word from the 
DAL line is loaded into Ratt: Ra regardless 
of the state of the Reply or Busy signal. 
Modify Instruction EC/ED (M!1B)V(Rb: Ra). The 16 bit contents of 
of next microm micro-instruction on the 
MIB lines to modify any or all of the next 
used to make on-line changes to micro- 
program flow. 
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Table 4-15 (ones) Microinstructions 


Load Translation — EE/EF (Rb: Ra)+(TR). The 16 bit contents of 
| registers Rb: Ra are transferred to the | 
Translation Register on the chip. This 
allows a translation of resultant data 
into a micro-instruction. 


Register 


~ Read and Increment 
Byte by | 


(Rb: Ra)e-DAL (Ra)+l+(Ra). The 16 bit 

address located in Rb:Ra is transferred 

to the DAL lines and a DATA READ 

operation is initiated. The contents of 

Ra are incremented by one. Rb !s 
__unchanged. 


(Rb:Ra)*DAL, (Rb)+!-(Ra). The 16 bit 
address located in Rb;Ra is transferred 


Write and Increment 
Byte by | 
to the DAL lines and a DATA WRITE 
operation is initiated. The contents qf Ra 
are incremented by one. Rb is unchanged. 
(Rb:Ra)*DAL, (Ratt: Ra)+!-(Ratl: Ra). 
The 16 bit address located in Rb; Ra is 
transferred to the DAL lines and a DATA 
READ operation is initiated. The contents 
of Rat+l:Ra are incremented by one. 
(Rb: Ra)*DAL, (Ratl: Ra)+l-(Ratt: Ra). 
The 16 bit address located in Rb: Ra is 
transferred to the DAL lines and a DATA 
WRITE operation is initiated. The con- 
tents of Ratl:Ra are incremented by one. 
(Rb:Ra)*-DAL, (Ra)+2+(Ra). The 16 bit 
address located in Rb:Ra is transferred to 
the DAL lines and a DATA READ operation 
is initiated. The contents of Ra are incre- 
mented by 2. Rb remains unchanged. 
(Rb:Ra)*DAL, (Ra)+2+(Ra). The 16 bit 
address located in Rb:Ra is transferred 
to the DAL line and a DATA WRITE 
operation is initiated. The contents of 
Ra are incremented by 2. Rb is not changed. 

(Rb:Ra)*DAL, (Rat+!l:Raj+2+(Ratl: Ra). 
The 16 bit address located in Rb: Ra is 
transferred to the DAL lines and a DATA 
READ operation is initiated. The content 
of Ratl:Ra are incremented by 2. 
(Rb:Ra)*-DAL, (Rat+l: RaH2+(Ratl:Ra). The 
16 bit address located in Rb: Ra is transferred 
to the DAL lines and a DATA WRITE 
operation is initiated. The contents of 
Ratl:Ra are incremented by 2. 
(Rb:Ra)*DAL. The 16 bit address located 
in Rb: Ra is transferred to the DAL line 
and a DATA READ operation is initiated. 

(Rb:Ra)*~DAL. The 16 bit address located 
in Rb: Ra is transferred to the DAL lines 
and a DATA WRITE operation is initiated. 
(Rb:Ra)+(DAL, l+lACK. The 16 bit address 
located in Rb: Ra is transferred to the 
DAL lines and a DATA READ operation 
is initiated. The interrupt acknowledge 


WIBI 


RIB2 


TI 
a) 


Read and Increment 
Word by | 


nN 
GO 


~ Write and Increment 
Word by | 


Read and Increment 
Byte by 2 


WIB2 


Write and Increment 
Byte by 2 


TI 
oT 


n 
oO 


: Read and Increment 
Word by 2 


ge Sad: Increment 
Word by 2 


s| g 

@ | Q 

“T) “Ti mal 
ye 
2 =| | 
ye 


Read Acknowledge 


(Rb: Ra)-DAL, I-lACK. The 16 bit address 
located in Rb: Ra is transferred to the DA! 
lines and a DATA WRITE operation is 
initiated. The Interrupt Acknowledge 

line is set high. - 


Write Acknowledge FB 


= 
> 
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Table 4-15 (Cont.). Microinstructions = 


Output Byte 1 (min.) | (Rb: Ra)-DAL, |-DOUT. The 16 bit 
data contents of Rb Ra are transferred 
- of 


to the DAL lines. Registers Ra and Rb 
Output Status 
No Operation FF 


are unchanged. The DATA OUT signal 
is activated. This instruction is completed 
when the REPLY signal is received 
Table 4-16. Summary of Microinstruction and Status Flags 
ALU Status hee a 
OP Code Microcycles NB ZB C4 
as NE 8 toon eee 


same byte is placed in both 8 bit positions 
on the DAL. 
(Rb: Ra)-DAL, |-DOUT. The 16 bit data 
contents of Rb: Ra are transferred to the 
DAL lines. The DATA OUT signal is 
activated. Registers Ra and Rb are 
unchanged. This instruction is complete 
when the REPLY signal is received from 
the addressed unit. 
(Rb:Ra)*DAL. The 16 bit contents of 
registers Rb: Ra is transferred to the DAL 
lines and takes place regardless of the 

state of the Reply or Busy signal. DOUT 

is NOt activated and Sync is not terminated. 
Registers Rb and Ra are unchanged. 


This instruction causes no operation. 


from the addressed unit. For byte 
operations Rb must equal Ra so that the 
JMP 
RFS foo @ | w--++----- 


NO RO 


B. Conditional Jump 
Format 


Bit 15-12 1-8 7-0 


JZBF | 0 ADDR 2 
JZBT 1 1 ADDR 2 
JC8F 1 2 ADDR 2 
JC8T 1 3 ADDR 2 
JIF 1 4 ADDR 2 
JIT 1 5 ADDR 2 
JNBF 1 6 ADDR 2 
JNBT 1 7. ADDR 2 
JZF 1 8 ADDR 2 
JZT 1 9 ADDR 2 
JCF 1 A ADDR 2 
JCT 1 B ADDR 2 
JVF 1 C ADDR 2 
SVT 1 D ADOR 2 
JNE 1 E— ADDR 2 
JNT 1 F  ADOR 2 


C. Literal Format 


Bit 15-12 11-4 3-0 


AL 2 Lit a 1 . . “« : ee = ms 
CL 3. Lit a 1 * | we = i wee 2s 
NL 4 Lit a 1 : a ne a ee 
TL 5 Lit a 1 . Fe ees = fy Ta Fs 
EL 6 Lit a 1 . a ae fe a ee 
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Table 4-16. (Cont.). Summary of Microinstruction and Status Flags 


ALU Status Flags 


Conditon Flags 


Mnemonic OP Code Microcycles NB ZB C4 C8 Z Vv C 
). Register Format | Bit 15-8 74 3-0 
RI 70 b x 1 
S| 71 b x 1 
CCF 72 x a 1 
LCF 73 b a 1 
RTSR 74 x x 1 
LGL 75 x a 1 . 
CIB 76 x a 1 . . . : 
CDB 77 x a 1 ‘s . . : 
MB 80/8 1 b a 1 ss . - . - ) 
MW 82/83 b a 2 . is . . ) 
CMB 84/85 b a 1 (* y : 0 -).C 
CMW 86/87 b a 2 (* 7 - . 0 -).C 
SLBC 88/89 b a 1 . : : ' . * . : 
SLWC 8A/8B b a 2 . . . - 4 : 
SLB 8C/8D b a 1 : . . = . . . : 
SLW 8E/8F b a 2 . . . ss . : . 
ICB 90/91 b a 1 . . . . . . : - 
ICWI 92/93 b a 2 i : . . : * . ' 
ICBZ 94/95 b a 1 ii 7 * . : . . : 
ICWZ 96/97 b a 2 is : . : : . 
TCB 98/99 b a 1 m . . : : . . * 
TCW 9A/9B b a 2 ‘ . . = : . . 
OCB 9C/9D b a 1 ss 7 0 0 : - 0 1 
OCW 9E/OF b a 2 sd : 0 0 7 7 0 1 
AB AQ/A1 b a 1 . ‘i = : . " ' . 
AW A2/A3 b a 2 7 : ‘ . . " . 
CAB A4/A5 b a 1 (* ‘ . ? . . . sis i 8 
CAW A6/A7 b a 2 C : sf . . * ¥ AC 
ABC A8/A9 b a 1 . . * . : * . 
AWC AA/AB b a 2 . . : , . ‘ ‘ 
CAD } AC b a 1 * * * * * * * 
CAWI 1 AE/AF b a 2 (* 3 . 7 ° * : a 
SB B/B1 b a 1 . . . : : o. * 
SW B2/B3 b a 2 : ' . : * . . 
CB B4/B5 b a 1 : ‘ . . . : . 
SW B6/B7 b a 2 : ° . . . * * . 
SBC 7 B8/B9 b a 1 . : ‘ . ‘ . . 
SWC BA/BB b a 2 . " : . . . 7 * 
DBI BC/BD b a 1 : . . : : : : : 
DWI BE/BF b a 2 : ° : . . . : 
NB CWCI b a 1 . . = : 0 
NW C2/C3 b a 2 . . : . 0 
TB C4/C5 b a 1 : i : . 0 
TW C6/C7 b a 2 ' . . ) 
ORB C8/C9 b a 1 . sf - = 0 

ORW CA/CB b a 2 : * * . 0 
XB CC/CD b a 1 : ” . . 0 
XW | CE/CF b a 2 = - = 0 
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Table eee Genes Summary of Microinstruction and Status Flags 


ALU Status Flags Condition Flags | 
OP Code Microcycles NB ZB C4 wi ~ V 


D. Register Format Bit 15-8 


NCB DOWD! 
NCW D2/D3 
SRBC D8/D9 
SRWC DA/DB 
SRB DC/DD 
SRW DE/DF 
1B EWE1 
IW E2/E3 
ISB E4/E5 
ISW E6/E7 
MI EC/ED 
LTR EE/EF 
RIB! FO 
WwiBI FA 
RIWi F2 
WIWI F3 
F4 
F5 
| F6 
F7 
F8 
FQ 
FA 
FB 
FC 
FD 
FE 
FF 


od 
r=) 
oo oo Qo 0 00 00 


mee eee eed eet A A em = AD AQ = = AQ —= AQ — AQ — A) = A) = A) —s 


Fx eo oooaowovopeweeooosoonsoaeooawoaweoeaeanaa ® ow 
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4.3.5 MICROINSTRUCTION BUS OPERATION. 

The Microinstruction Bus interconnects the three different 
Circuits that make up a MCP1600 Microprocessor system. Con- 
nected to the Microinstruction Bus can be one CP1611B Data 
Chip, one CP1621B Control Chip, and as many as four CP1631B 
Microinstruction ROM Chips. There may also be user supplied 
TTL logic connected to the Microinstruction Bus in a fashion 
to be defined below. 


The discussion below describes the 22 different lines on the 
Microinstruction Bus from the standpoint of each of the various 
types of devices attached to it and from the standpoint of user 
attached devices. Figure 4-41 illustrates the system inter~ 
connections. 


@ @2 63 64 E 


MiB 18- 


61 62 63 04 


DATA 


CHIP DALO-15 (TTL) 


CP1611B 


RPLY (TTL) 
BUSY (TTL) 
SYNC (TTL) 
OIN (TTL) 

DOUT (TTL) 
ws (TTL) 

{ACK (TTL) 


Figure 4-41. System Interconnections Microprocessor Set 
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4.3.5.1 BUS OPERATION. 

The Microinstruction Bus consists of 22 lines. These lines 
are precharged by. each of the microinstruction ROMs attached 
to the bus. Most generally, the lines are precharged high 
during $4 but MIB15 is precharged high during #3 and MIB16 

1s charged high during both #2 and $4. The microinstruction 
bus conveys its information by conditional discharge at the 
appropriate phase times. The microinstruction bus is a MOS 
compatible 4 phase bidirectional bus, and data on the bus is in 


logical complement form. 


Table 4-17 defines the meaning of each of the lines on the 
bus at each phase time on the bus. Note that some lines 


have more than one meaning, depending upon the phase time. 


4.3.5.2 MICROINSTRUCTION BUS ELEMENT DESCRIPTION. 
The Microinstruction Bus is divided into seven partitions. 
These partitions can carry data in both directions. They 
assume different meanings at different points in the clock 
cycle of the processor set. This section describes each 
element and its meaning as a function of the phase time in 


each clock cycle. 


MIBOO-MIB10. These lines serve to carry data bidirectionally 
between microinstruction ROMs and the Data and Control Chips. 
They are unconditionally precharged Hi at $4 by the MICROMS 
attached to the bus. At the following §1, they may have two 
different meanings depending upon whether the Microinstruction 


presently being executed is a one cycle or a two cycle instruction. 


If the Microinstruction executes one cycle, then the next 91 
conveys the next microinstruction from the Microinstruction ROM 
to the Data Chip and Control Chip. If the Microinstruction 
takes two cycles, the second occurrence of #1 may result in 
data being transferred from the Data Chip to the Control Chip. 
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Table 4-17. Microbus Timing 


a 


MIBO0-MIB10 — Address Data 


to MICROM 
MIB11-MIB14 
MIB15 | 


MIB16 


— Precharge 
by MICROM 


— Address must 
remain valid 


— Microinstruction from ROM 
to Data Chip and Control 


Second Cycle of 2-Cycle 
Instruction: Data from 
Data Chip to Control Chip. 


— Precharge 
by MICROM 


Microinstruction from ROM 
to Data Chip and Control 
Chip 


— Second Cycle of 2-Cycle 
Instruction: Data from 
Data Chip to Control Chip. 


Conditional 
Jump Results 


— Precharge 
by MICROM 


— Microinstruction from ROM 
to Data Chip and Control 
Chip. 


Second Cycle of 2-Cycle 
Instruction: Data from 
Data Chip to Control Chip. 


Disable 
MICROM 
Outputs at 
next 01 


Precharge 
by MICROM 


— Precharge 
by MICROM. 


Load Return Register 


Precharge 
by MICROM 


Precharge 
by MICROM 


At $2, address data is transferred from the Location Counter 
in the Control Chip to the MICROM. At §3,the address data 
remains valid on the bus. The processor cycle is completed 
by an unconditional precharge of these lines by the MICROM 
at 4. 


MIB11-MIB14. These lines serve to convey Microinstruction data 


from the Microinstruction ROM to the Data and Control Chips 
in much the same fashion as the preceeding lines do. These lines 
are unconditionally precharged Hi by the MICROM at 4. At #1 
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of a single cycle, they are conditionally discharged to represent 
Microinstruction Data from the Microinstruction ROM to the Data 
Chip and the Control Chip. 


If the preceeding Microinstruction was of the 2-cycle variety, 
the second occurrence of §1 on these lines can carry data from 
the Data Chip to the Control Chip. These lines have no other 

Significance during $2 and 93. 


MIB15. MIB 15 is used to carry Microinstruction data from the 
ROM to the Data Chip and Control Chip and also to transfer the 
results of conditional jump tests from the Data Chip to the 
Control Chip. 


This line is precharged Hi unconditionally by the Microinstruc- 
tion ROM at 93. At #4, it can be conditionally discharged 
by the results of a conditional jump test. 


At §1 this line conveys the microinstruction data from the 

ROM to the Data and Control Chip. In the case of a micro- 
instruction whose execution takes two cycles, the second 
occurrence of #1 may serve to convey data from the Data Chip 

to the Control Chip. The contents of MIB15 are not significant 
at #2. The cycle is completed by an unconditional precharge 

of MIB1S at 93. 


MIB16. This control line conveys data from the ROM to the 
Control and Data Chips and from the Control Chip to the Micro- 


instruction ROM. It is unconditionally precharged HI at both 

$2 and 94. At $1 following $4, it may conditionally discharge 

low by the MICROM; in which case, the signal is interpreted by the 
Control Chip as a command to load the subroutine Return Register _ 
with the incremented content of the Location Counter. On §2, 

the lines are unconditionally precharged Hi. At §3, the Control 
Chip may conditionally discharge these lines. If it does so, 

this is an instruction to the selected MICROM (Microinstruction 


ROM) to disable its outputs at the next #1. In this fashion, 
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2 cycle instructions inhibit the transfer of new microinstruc- 
tions from the MICROM to the Control Chip and the Data Chip. 


MIB17. MIB17 has but one purpose. This is to convey the READ 
NEXT INSTRUCTION imperative from the MICROM to the Control Chip. 
This line is unconditionally precharged by the MICROMs attached 
to the Microinstruction Bus and conditionally discharged at 91.. 
A discharge indicates that the RNI imperative is required. 


MIB18-MIB21. These lines are not part of the Microinstruction 
Bus in that they do not transfer data between the Micro- 
instruction ROM and the Data Chip and the Control Chip. They 
are TTL level outputs capable of driving one TTL load per line. 
They represent four bits in the Microinstruction word and are 
made valid at the same time as the other outputs of the MICROM, 
1. The lines are unconditionally precharged Hi by the MICROM 
at $4 and conditionally discharged Low according to the contents 
of the word at $1. The user may set these outputs in any 
fashion he chooses. They remain valid in the inclusive interval 
01 to 93. Figure 4-42 illustrates their timing. 


WAIT Line. The WAIT Line from the Control Chip to the Data 

Chip establishes whether or not the Data Chip is in the RUN 

or WAIT mode. Whenever the WAIT control line is in the Low 
state, the Data Chip is in the RUN mode and the Microinstruction 
will be loaded into the MIR register and executed. This line 

is normally Low and must be driven Hi during §4 to cause the 
Data Chip to enter the WAIT state. It always returns to Low 
when the beginning edge of the $1 clock appears. 


A719 


PHASE 
2 
CLOCK 
PHASE 
3 
4a 
CLOCK 
PHASE 
4 
Trou. t 
eo 

v 
(MIBi8-MiB71) wal 

Vout 
CS cee, Ba ee ees te Viena 


Vv 
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NOTE: TTL OUTPUTS (MIB18- MiIB21) ARE UNCONDITIONALLY ORIVEN HIGH AT 64 AND 
CONO!TIONALLY ORIVEN LOW AT @1 THIS CONDITIONAL LOW WILL BE VALIO 
UNTIL THE NEXT 04 


Figure 4-42, TTL Output Timing CP1631B 
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4.3.5.3 DATA CHIP. 

The CP1611B Data Chip interacts with a subset of the Micro- 
instruction Bus. Lines MIBOO-MIB15 are present at the Data 

Chip. They convey Microinstructions from the Microinstruction. 
ROM to the Data Chip, and they convey data from the Data Chip to 
the Control Chip. MIB1i5 also has a use as a control line con- | 
veying the results of conditional jump sets. 


During the first $1 of a two cycle instruction, data is trans- 
ferred from the microinstruction ROM into the MIR register of 
the Data Chip. The microinstruction bus is not sampled during 
~2 and 93. At $4, the Data Chip may conditionally discharge 
MIB15 to indicate the results of a conditional jump test. At 
the second occurrence of $1 of a two cycle instruction, the 

Data Chip may or may not transfer data to the Control Chip. 

If the two cycle instruction was of the Jump class or word 
operation class, the Data Chip will not transfer data to the 
Control Chip. If the two cycle instruction was a LTR or IW 
instruction (with the appropriate bits in the control field 
properly set), then the Data Chip transfers 16 bits of data into 
the Control Chip. This data is gated into the Translation Regis- 
ter on the Control Chip. 


During the execution of a one cycle microinstruction, data is 
only transferred from the microinstruction ROM to the Data 
Chip. This transfer occurs at $1. Figure 4-43 illustrates 
the timing of the Microinstruction bus interface as seen by 
the Data Chip. 


4.3.5.4 CONTROL CHIP. a 

The CP1621B Control Chip interfaces with the MIBOO-MIB17 as 

the Data bus. Data can come to the Control Chip from both the 
Data Chip and the Microinstruction ROM. From the Microinstruc- 


tion ROM,the Control Chip can receive microinstructions into 
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PHASES @1 02 @3 4 61 
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NOTE SWITCHING TIMES ARE MEASURED AT 10% AND 90% OF SPECIFIEO LEVELS. 


Figure 4-43. Microinstruction Bus Interface Timing 


the MI register. There these microinstructions are used to 
drive the Master Control function and are also present in the 
event that the Microinstruction is of the jump variety anda 
jump is required. Data from the microinstruction ROM also is 
presented on MIB16, which controls whether or not the Return 
Register will be loaded with the incremented contents of the 
Location Counter. MIB17 from the Microinstruction ROM, controls 
whether or not the RNI translation will be invoked. Data from 
the Data Chip to the Control Chip can be passed over MIBOO-MIB15 
as a result of an LTR instruction or an IW instruction. MIB15 
is also used by the Data Chip to send the results to the Control 
.Chip's Master Control function informing it of the results of a 


conditional jump test. 


The Control Chip can generate a WAIT signal which goes to the 
Data Chip, and causes Data Chip operations to be suspended, 
pending the completion of an I/O operation. The Control Chip 
also generates a signal placed on MIB16 which enables or disables 


the outputs of selected microinstruction ROM. This is used 
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during the second cycle of the execution of two cycle instruc- 
tions to avoid conflicts on the microinstruction bus. The 
timing of the microinstruction bus as seen from the Control Chip 
is illustrated in Figure 4-44, 


NOTES: 1. BUS PRECHARGING IS PERFORMED BY THE CP 16318. 
2. ADDRESS OUTPUT SWITCHING TIME (Troy AND Troy) APPLIES TO MIBGS MIBTI ONLY. 
3. JUMP RESPONSE FROM DATA CHIP CP 16118. 
4. SWITCHING TIMES ARE MEASURED AT 10% ANO 90% OF SPECIFIED LEVELS. 


Figure 4-44, Control Chip Microinstruction Bus Timing 


4.3.5.5 MICROINSTRUCTION ROM. 

The Microinstruction ROM interfaces with all 22 lines of the 
Microinstruction bus. It receives Microinstruction addresses 
on MIBOO-MIB10 from the Location Counter in the Control Chip. 
It also receives an ENABLE/DISABLE signal on MIB16. from the 
Control Chip. It sends data on MIBOO-MIB17 to the Control 
Chip and the Data Chip. MIBOO-MIB15 are presented to both the 
Control Chip and the Data Chip. These 16 bits comprise micro- 
instruction data for the Data Chip and the Control Chip to 
interpret. MIB16 is properly part of the microinstruction and 
controls whether or not the Return Register will be loaded 
with the incremented contents of the Location Counter. MIB17, 
also properly part of the microinstruction, controls whether 


or not the matrix represented by Arrays .1 and 2 will force a 
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user specified State code that will cause the "READ NEXT INSTRUC- 
TIONS" translation to be performed. The interface of the micro- 
instruction ROM to the microinstruction bus is illustrated in 


Figure 4-45. 


a 1s precharged at 03 


TPRE applies 


. MIB LINES EXCEPT MIBIB ARE PRECHARGED HIGH AT PHASE 4 
_ 1B16 IS ALSO PRECHARGED HIGH AT PHASE 2 


NOTES: 1 
2 
3. MiB16é IS DISCHARGED TO DISABLE THE MIRED MIB1S AND MIBIB MIB21 OUTPUTS 
a 
5 


AT 61 FROM DISCHARGING LOW. 
. AODRESS INPUT TRANSISTIONS OCCUR ONLY ON M1B@6 M1816 LINES AND CHIP SELECT. 
. SWITCHING TIMES ARE MEASURED AT 10% AND 90% OF SPECIFIED LEVELS. 


Figure 4-45. Microinstruction Bus Timing CP1631B 


4.3.6 DATA ACCESS. | 
Communications between the MCP1600 system and attached peri- 
pheral devices or memory is conducted via a path called the 
Data Access Bus. The Data Access Bus consists of 16 data lines 
(DALOO-DAL15), 7 control lines and 4 interrupt lines. The 
operation of these elements is controlled by the Input/Output 
Class of instructions. 


The Data Access provides a single 16 bit bidirectional path 


to and from the processor for transfer of data and addresses. 
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A number of different types of bus arrangements are possible 
with the data access, such as: | 


eCommon data and address 
eSeparate data and address 


*Separate input and output busses 


The Data Access Bus provides for 16 bit address and either 8 
or 16 bit data (addresses are conventionally deemed to be byte 
addresses) and provide a maximum addressing capability of 65k 
bytes. 


In accessing data, no:distinction is made between memory and 
peripheral units or between instructions, data, control, or 
Status. Each byte or word of information, regardless of 
function, is assigned an address and is referenced by means 
of this address. 


In essence, then the Data Access Bus can be conceived to consist 
of the following elements: 


eData Lines (DALO0-DAL15) 

eControl Lines (SYNC, REPLY, DATA-OUT or DOUT, DATA=-IN 
or DIN, WRITE/BYTE, IACK, BUSY) 

*Processor Control Lines (10, 11, 12, 13, COMPUTE, RESET) 


The remainder of this section describes each of these elements 


of the data bus and their interactions and timings. 


4.3.6.1 INPUT/OUTPUT INSTRUCTIONS. 
This section breaks the I/O Instruction class into 5 classes. 
These classes are: | 


eControl Instruction consisting of the READ and WRITE 


INSTRUCTIONS that serve mainly to operate the Control 


Lines on the Data Access and to provide addresses. 
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*Data Transfer Instruction, consisting of the INPUT and 
OUTPUT instructions which serve to pass data along the 
Data Access lines. 


@®ACKNOWLEDGE instructions which serve to respond to 


interrupts. 


Figure 4-46 illustrates the condition testing performed prior 
to executing the Input/Output instructions. The execute 
function is described in the following sections. 


READ Instructions. The READ instructions take a 16 bit address 
from a designated register pair and transfer it to the M regis- 
ter. When the address becomes valid on the bus, (during the 
following $1) the SYNC line is made high. The variations 

on the READ instruction are primarily for address manipulation 
and easing the coding of I/O routines. They cause the address 
source registers to be modified in some fashion. As far as 

the system designer is concerned, the pertinent operation of 
this instruction class is that it causes the selected address 
to be placed on the Data Access lines (DALOO-DAL15) and the 
SYNC line to be raised. The addressed device asserts the REPLY 
Line when ready for the data transfer. A flow diagram of the 


READ instruction operation is shown in Figure 4-47. 


R b, a READ 


The 16-bit address in Registers Rb:Ra is transferred to the M 
Register and a DATA READ operation is initiated. Registers Rb 


and Ra are not changed. 


Timing: 1 cycle 
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~ COMPUTE 
ASSERTED AT 
61 


BUSY 
ASSERTED? 


MIR = 
STATUS OPN 
2, oe 


REPLY @ @3 
ASSERTED 
? 


MIR = 
READ OR WRITE 
? 


MIR = 
INPUT OR 
OUTPUT 
? 


REPLY 
ASSERTED 


@ 
03? 


EXECUTE 


Figure 4-46. I/0 Instruction Condition Testing 
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EXIT 


STILL ASSERTED 


A 
03? 


F 


ADDRESS ~ DALOO-15 


ASSERT SYNC 


EXIT 


Figure 4-47. Execution of Read Instruction 
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RiB1 b. a READ AND INCREMENT BYTE BY 1 


The 16-bit address in Registers Rb:Ra is transferred to the M 
Register and a DATA READ operation is initiated. The contents 
of Register Ra are incremented by 1. Register Rb is not changed. 


Timing: 1 cycle 


RIB2 b. a READ AND INCREMENT BYTE BY 2 


The 16-bit address in-Register Rb:Ra is transferred to the M 
Register and a DATA READ operation is initiated. The contents 


of Register Ra are incremented by 2. Register Rb is not changed. 


Timing: 1 cycle 


RIW1 b, a READ AND INCREMENT WORD BY 1 


The 16-bit address in Registers Rb:Ra is transferred to the M 
Register and a DATA READ operation is initiated. The word in 


Rat+1:Ra is incremented by l. 
Timing: 2 cycles 
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The 16-bit address in Registers Rb:Ra is transferred to the M 
Register and a DATA READ operation is initiated. The word in 


Rat1:Ra is incremented by 2. 
Timing: 2 cycles 


Write Instructions. This class of instructions causes an address 
in a designated register pair to be placed on the Data Access 
lines DALOO-DAL15. The SYNC line is raised as the address 
becomes valid at the next occurrence of $1. Also the WRITE-BYTE 
line is raised during the next occurrence of $1. When the 
addressed device is ready to transfer data, it asserts the 

REPLY line. 


The comments about address source register manipulation pertain 
to this class of instructions as they do to the READ class of 


instructions described above. 


A DATA WRITE operation is distinguished from a DATA READ opera- 
tion by the assertion of WRITE/BYTE at the same time the address 
becomes valid on the bus. Note carefully that this signal 

later is used to describe data length when the data becomes 


valid on the bus. 


A flow diagram of the WRITE instruction operation is shown in 


Figure 4-48. 
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F 
EXIT 


REPLY 
ASSERTED 


F 
ADDRESS ~ DALOO-15 
ASSERT WRITE/BYTE 
ASSERT SYNC 


EXIT 


Figure 4-48. Execution Write Instruction 
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The 16-bit address in Registers Rb:Ra is transferred to the M 
Register and a DATA WRITE operation is initiated. Registers 
Rb and Ra are not changed. 


Timing: 1 cycle 


WIB1 b, a WRITE AND INCREMENT BYTE BY 1 


1§ 8 4 0 


The 16-bit address in Registers Rb:Ra is transferred to the 
M Register and a DATA WRITE operation is initiated. The con- 
tents of Register Ra are incremented by 1. Register Rb is 
not changed. 


Timing: 1 cycle 


WIB2 b, a WRITE AND INCREMENT BYTE BY 2 


15 8 4 


=) 


The 16-bit address in Registers Rb:Ra is transferred to the M 
Register and a DATA WRITE operation is initiated. The contents 
of Register Ra are incremented by 2. Register Rb is not changed. 


Timing: 1 cycle 


WIW1 b, a WRITE AND INCREMENT WORD BY 1 
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The 16-bit address in Registers Rb:Ra is transferred to the M 
Register and a DATA WRITE operation is initiated. The word in 
Rat1:Ra is incremented by a. 


Timing: 2 cycles 


WIW2 b. a WRITE AND INCREMENT WORD BY 2 


15 8 4 0 


The 16-bit address in Registers Rb:Ra is transferred to the M 
| Register and a DATA WRITE operation is initiated. The word in 
Rat+1l:Ra is incremented by 2. 


Timing: 2 cycles 


INPUT Instructions. The INPUT Instructions control transfer 

of data from external devices on the Data Access to the pro- 
cessor. The data present on the data access is input by the 
instruction to the specified register or register pair. The 
INPUT class of instructions will not execute until a REPLY 
Signal has been received from the device addressed by the 
previous READ instructions. Refer to a description of the 
REPLY signal below for the timing required. When this instruc- 
tion is executed,it sets DATA-IN high to inform the addressed 
device that it should place its data on the bus. This instruc- 
tion terminates by making SYNC and DATA-IN Low on the 92 

after completion. 


Note that the instructions INPUT STATUS BYTE and INPUT STATUS 
WORD execute regardless of the state of the REPLY signal. Other 
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than this exception, these two instructions are identical to the 
rest of the INPUT class instructions. 


Note also that there are no timing restrictions after the 
selection of a device. As long as the operations are executed 
in the proper sequence, no timeouts or arbitrary disciplines 


bother the system designer. 


The flow diagram in Figure 4-49 illustrates the operation of 
the INPUT instruction. 


The 8-byte from the Data Lines, as specified by b, is placed in 
Register Ra. Code El causes the condition flags, except C, to 
be updated. The Read Data Access operation is terminated unless 
Bit 6 is a one which allows a Read-Modify Write (RMW) requiring 
termination by an output instruction. The instruction will not 
execute until after a Reply signal has been received from the 


addressed unit. The optional inputs are listed below: 


b = 0 Upper Byte (Bits 15-8) 

b= 1 Lower Byte (Bits 7-0) 

b = 2 Upper Byte if M(0) = 1; Lower Byte if M(0) = 

b = 3 Lower Byte if M(0) = 1; Upper Byte if M(0) = 

b= 4 Upper Byte (Bits 15-8); RMW 

b= 5 Lower Byte (Bits 7-0); RMW 

b = 6 Upper Byte if M(0) = 1; Lower Byte if M(0) = 0; RMW 

b= 7 Lower Byte if M(0) = 1; Upper Byte if M(0) = 0; RMW 
Timing: 1 cycle (minimum) 
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EXIT 


REPLY 
AND DIN 
ASSERTED? 


T 


INPUT LOW BYTE 


WORD 
OPERATION 


INPUT HIGH BYTE 


EXIT 


Figure 4-49. Execution of Input Instruction 
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Iw ob, a INPUTWORD 


The 16-bit word from the Data Lines is placed in Registers Ratl: 
Ra. Code E3 causes the condition flags, except C, to be updated. 
The Read Data Access operation is terminated unless Bit 6 is 

a one, which allows a Read-Modify-Write (RMW) operation requiring 
termination by an Output instruction. If Bit 4 or 5 is a one, the 
word on the Data Lines is loaded in the Translation Register; 

and at the same time, either Bits 6-4 or Bits 8-6 of the DAL are 
loaded into the G Register. The instruction will not execute 
until after a Reply signal has been received from the addressed 
unit. The Lower Byte is loaded before the Upper Byte. The 

b options are listed below: 


b = 0 
b = 1 + 4Load TR; DAL 6-4 to GR; Sets ICS 
DS 2 Load TR; DAL 8-6 to GR; Sets ICS 
b = 3 Load TR; Sets ICS 
b= 4 RMW 
b= 5 Load TR; DAL 6-4 to GR; RMW; Sets ICS 
b = 6 Load TR; DAL 8-6 to GR; RMW: Sets ICS 
b = 7 Load TR; RMW; Sets ICS 
Timing 2 cycles (Minimum) 


ISB) b, a INPUT STATUS BYTE 


The 8-bit byte from the Data Lines, as specified by b, is 
placed in Register Ra. Code E5 causes the condition flags, 
except C, to be updated. The instruction will input regard- 
less of the state of the Reply signal. These optional inputs 


are listed below: 


4-129 


0 Upper Byte (Bits 15-8) 

1 Lower Byte (Bits 7-0) | 

= 2 Upper Byte if M(0) 1; Lower Byte if M(0) 
3 
1 


Lower Byte if M(0) = 1; Upper Byte if M(0) 
cycle | 


ISW b, a INPUT STATUS WORD 


The 16-bit word from the Data Lines is placed in Registers Ratl: 
Ra. Code E7 causes the condition flags, except C, to be updated. 
This instruction inputs regardless of the state of the Reply 
Signal. The Lower Byte is loaded before the Upper Byte. 


Timing: 2 cycles 


OUTPUT Instructions. OUTPUT Instructions cause data to be 
transferred from the processor to the addressed peripheral 
devices. The OUTPUT instructions need the REPLY signal to 

be asserted before exécution will proceed. DATA=OUT is set 

Hi by the processor during the first phase of the instruction 

to inform the peripheral device that data is presently available 
on the Data Access. Also during this time, the WRITE/BYTE 
Signal may be set to indicate the length of data on the bus. 


The OUTPUT STATUS command operates as the OUTPUT instructions 
except that it does not pay attention to the state of the REPLY 
line. | | 


After the execution of the OUTPUT instruction, data becomes 
valid on the bus. Also, at this time, WRITE/BYTE is asserted 
if the data size is one byte. If the data size is a word, 
WRITE/BYTE becomes passive. 


Refer to Figure 4-50 for the flow diagram of the OUTPUT 


instruction operation. 


4-130 


EXIT 


PLACE DATA ON DALOO-15 


T 
ASSERT DOUT 


ASSERT WRITE-BYTE RESET WRITE-BYTE 


Figure 4-50. Execution of Output Instruction 
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The 16-bit contents of Registers Rb:Ra are transferred to 
the M Register and the Data Lines. The Data Out signal is 
activated. Registers Rb and Ra are not changed. To provide 
proper operation with a 16-bit Data Path, b must equal a so 
that the same byte is placed in both byte positions of the 

M Register. Output does not take place until Reply has been 
received from the addressed unit. 


Timing: 1 cycle (minimum) 


OW b. a OUTPUT WORD 


The, 16-bit contents of Registers Rb:Ra are transferred to the 
M Register and the Data Lines. The Data Out signal is acti- 

vated. Registers Rb and Ra are not changed. Output does not 
take place until Reply has been received from the addressed unit. 


Timing: 1 cycle (minimum) 


OS b, a OUTPUT STATUS 


The 16-bit contents of Registers Rb:Ra are transferred to the 
M Register and the Data Lines. Registers Rb and Ra are not 
Changed. Output takes place regardless of the state of the 
Reply signal. This instruction is normally used without a 


Write instruction and cannot turn off Sync. 


Timing: 1 cycle 
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Interrupt Acknowledge Instructions. These instructions perform 
in identical fashion to the READ/WRITE instructions. Additionally, 
they raise the Interrupt Acknowledge (IACK) line. The Interrupt 


Acknowledge signal and a predetermined address placed on the 
Data Access bus by this instruction can be used as a signal 

to the I/O devices to inform the I/O set that the device requesting © 
service should place its device number on the bus for transmission 

to the processor. Depending upon whether or not a READ acknowledge 
or a WRITE acknowledge was executed, the succeeding instruction 

may be an INPUT or OUTPUT Instruction respectively. 


RA b. a READ ACKNOWLEDGE 


The 16-bit address in Registers Rb:Ra is transferred to the M 
Register and a DATA READ operation is initiated with the 
Interrupt Acknowledge line high. Registers Rb and Ra are not 
changed. The Interrupt Acknowledge signal along with one or 
more address bits is used to form a signal which polls I/O 
units for the one interrupting the processor on the Interrupt 
line corresponding to the address. The processor inputs a 
byte or word containing the identification of the interrupting 


unit. 


Timing: 1 cycle 


WA b., a WRITE ACKNOWLEDGE 


The 16-bit address in Registers Rb:Ra is transferred to the 
M Register and a DATA WRITE operation is initiated with the 
Interrupt Acknowledge line high. Registers Rb and Ra are not 
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changed. The Interrupt Acknowledge signal along with one or 
more address bits is used to form a signal which polls I/O 
units for the one interrupting the processor on the Interrupt _ 
line corresponding to the address. This unit receives the 
next data output. | 


Timing: 1 cycle 


4.3.6.2 DATA/ADDRESS LINES. 

Sixteen Data/Address Lines, denoted DALOO-DAL15, are used to 
transfer addresses and data from the processor and to receive 
data into the processor. This bus is TTL compatible and 
Signals on it are logical true data. 


An address is output by the Data Chip as a result of executing 
_a@ READ or a WRITE instruction. It appears on the bus at #1 
following the execution of the instruction. The address is 
valid on the bus during phases 2, 3 and 4. 


Data is output by the processor as a result of executing an 
OUTPUT instruction. It appears on the bus at the first 91 
after the microinstruction is executed and remains on the 
bus for a minimum of one cycle. Data is received from the 
Data Access into the processor by the INPUT instruction. It 
is clocked in at $4 of the instruction cycle. 


4.3.6.3 CONTROL LINES. 

This section describes the Control lines generated by the 
CP1621 Control Chip as a result of I/O instruction execution. 
It provides a functional description of the control lines. 
Their timing and interactions with the Data Access lines are 
further defined in Section 4.3.6.5. 


Sync (TTL). The SYNC is a Control signal used to initiate and 


Signify the length of a Data Access operation. SYNC is made 
high as soon as an address becomes valid. This occurs at 92 
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following a READ or WRITE. It remains high until the termina- 


tion of the operation. 


Reply (TTL). The REPLY is a Control signal used by the addressed 


unit to respond to the Processor's Data Access signals. 


The REPLY signal must be high during §3 of the INPUT or OUTPUT ~ 
microinstruction execution cycle in order to complete this opera- 
tion. The REPLY signal is also interrogated by READ and WRITE 
microinstructions, and it must be low during #3 for these operations 


to take place. 


Data-In (TTL). The DATAIN (DIN) is a Control signal from the 
Processor that causes the address unit to gate its Read data on 
the Data lines. It is made high at the time the address is 
removed from the lines, or one cycle after the SYNC is made 
high (the second #2 of the INPUT) and is a function of the 

READ instruction. The DATA-IN is made low at the end of the 
Input Byte or Input Word instruction or when SYNC is made low. 
This signal can be used to control the enabling of external 


TTL Tri-State Bus Driver/Receivers. 


Data-Out (TTL). The DATA-OUT (DOUT) is a Control signal from 
the Processor which is made high at the same time as the Write 
data (#1 following the OUTPUT) is placed on the DAL bus by the 
Processor. It remains high for the duration of the OUTPUT 
instruction, dropping one phase before the data is taken off 
the DAL bus. | 


Write/Byte (TTL). The WRITE-BYTE (WB) is a Control signal from 
the Processor which is high during the time the address is on 
the bus to signify a WRITE rather than a READ operation; and is 
high during Data-Out to signify a Byte output rather than a 

Word output. To indicate an Output, it comes up at #1 following 
a WRITE. 
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Interrupt Acknowledge (TTL). The IACK is a Control signal 
from the Processor which signifies that the Processor is 
responding to an Interrupt. This signal is made high at the 
same time the SYNC is made high as a result of either 'RA' 

or 'WA' instructions, and stays high as long as SYNC is high. 


Busy (TTL). The BUSY is a Control signal from an external unit 
to the Processor requesting access to the bus. The signal can. 
be used, for example, by a DMA unit to access the memory. The 
BUSY signal is interrogated at $3 by the Processor every time 
READ or WRITE instructions are taking place. Whenever the 

BUSY signal is found to be one, the Processor enters a WAIT 
State inhibiting any access operation from taking place. The 
Processor will resume normal operation as soon as BUSY is 
turned off. 


4.3.6.4 INTERRUPT, RESET, AND COMPUTE. 
This section describes signals which would, in the normal 


scheme of things, be defined as processor control signals. 


Reset. RESET is a TTL level line that may be controlled by an 
external device. Activation of the RESET line causes the 
Microprocessor to force 001 into the Location Counter. A NOP 
1s also forced into the MIR and the MI registers. SYNC and 
DATA-IN are both reset. The RESET line can be wired to a 
POWER ON reset, or it may be used by the program for its own 
purposes. 


Note that the activation of RESET is a hard action in that 
everything stops and the above mentioned conditions are forced. 


Compute. COMPUTE is also a TTL level signal and it controls 
the processor's execution of microinstructions. The processor 
examines COMPUTE during every §1 to determine whether or not 
it should execute the present microinstruction. In the case 
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of a two cycle instruction, COMPUTE need be high only during §1 
of the first cycle. Among other things, COMPUTE may be used 

to control single stepping of microinstructions. This line 
should not be confused with the WAIT signal on the MIB bus. 


Interrupts. The external INTERRUPT lines of the MCP1600 system 
are I0-1I3. These are microprogrammable. These lines provide 
inputs to Array 3 of the Programmable Translation Array and thus 
may be checked at certain user defined addresses in the Micro- 
program. As the examination of these lines is controlled by the 
contents of the Location Counter and the Macroinstruction being 
translated, it is easy for the microprogram to examine them for 
instance, before the FETCH cycle of every macroinstruction. 
There is no discipline associated with the use of these inter- 
rupt lines. Their state may be changed at any time. The system 
designer may implement his own interrupt control scheme by use 
of these lines and the ACKNOWLEDGE instructions. 


4.3.6.5 INPUT/OUTPUT OPERATIONS. 

The Data Access of the MCP1600, because of its flexibility, 

can be used to configure a variety of I/O schemes. Several of 
the schemes that can be implemented were mentioned in the intro-. 
duction. This section will describe the interactions of the 
elements that comprise the Data Access and then define some 
Canned operations that have been found useful. The combination 
of these canned operations and a discipline that structures 
interrupts and device addresses can result in a fast and powerful 


I/O structure. 


Standard I/O Sequences. There are five standard I/O sequences 
that have been developed for the MCP1600 Processor System. 
These sequences provide for-the orderly transfer of data to 

and from the processor. Two sequences provide for normal READs 
and WRITEs. One sequence provides a READ/MODIFY/WRITE capa- 
bility which is useful for controlling random access memory 
devices. The last two sequences are READ/WRITE INTERRUPT 
ACKNOWLEDGE sequences. 
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Note that in the timing diagrams, the first clock 
cycle (#1, --- 4) is devoted to instruction interpretation. 


Bus operations do not begin to occur until the second clock cycle. 


Write/Output Sequence. This sequence consists of two instructions: 
WRITE Device Number 
OUTPUT Data Source 


The write operation transfers data from the processor to the 
addressed unit. The Write is initiated by a Write instruction 
Which transfers a 16-bit address to the Data Access port. The 
address is present on the lines for one cycle. Data is trans- 
ferred from the processor registers to the Data Access port by 
an Output Byte or Output Word instruction. The operation is 
terminated after the data has been on the lines for a minimum 
of one cycle. When outputting a byte with a 16-bit data path, 
the same byte must be placed in both the upper and the lower 
bytes of the port and the addressed unit takes care of storing 
the byte in the proper half of the word as selected by the 
low-order address bit. 


The time period between selection of the device by the WRITE 
instruction and the transfer of the data is not critical if the 
device controller latches the selection. The sequence is 


graphically shown in Figure 4-51. 


Read/Input Sequence. This sequence consists of two instructions 
which select the device, then transfer data. 

READ Device Number 

INPUT Data Destination 


The Read operation transfers data from the addressed unit to 
the processor. The Read is initiated by a Read instruction 
which transfers a 16-bit address to the Data Access port. The 


address is present on the lines for one cycle and then the 
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processor signals the addressed unit to put its data on the 
lines, Data is input to the processor registers by an Input 
Byte or Input Word instruction. The Read operation is termi- 
nated by either Input or Output instructions. An Input Byte 
instruction allows for selection of the Upper Byte, Lower Byte 
or the Byte selected by the lower-order bit of the address. 


The time period between execution of the READ and INPUT INSTRUC- 
TIONS is not critical if selection latching is used in the 


device controller. 


Figure 4-52 illustrates the READ/INPUT sequence. 


WRITE OUTPUT WAIT) OUTPUT NE XT INSTRUC TON 
Ot Q? 07 04 0! 02 03 04 od] 07 03 on ot 02 ot om o 
wart , 
DAL 
<_apomiss OSC s—SsSsS 


2 ~~ ® 

~| XN — 

ai ; @ WRITE READ ae, co SPS vo eee, N- 
ee Ea. 

REPLY, . (2) ; x 


SVNC IS MADE HIGH AS SOON AS A VALID ADDRESS 1S O88 THE BUS (02) 
REPLY BEING 1 OW ON OF CAUSES THE COOTPUE INS TMU THON TO BE EXECUTED REPEATEDLY 
DOUT 1S MADE HIGH ON OLAS DATA OUT IS PLACED ON THE BUS 


OUTPUT INSTRUCTION IS TERMINATED BY RAISING REPLY BEFORE 03 
‘SYNC 1S MANE LOW ON 07 ‘DOUT IS MADE LOW ON O04 AND DAL IS TRISTATED ON 11 
REPLY CAN BE TURNED OF F AS SOON AS SYNC IS MADE LOW 


PF &wn — 


Figure 4-51. Write/Output Sequence 


READ INPUT VALID. {INPUT LOW BYTETINPUT HIGHBYTE 
01] 02] 03 | 04] 01{ O02 | O3 | O04] 01] 02 | 03 | 04] 01 24,03] 4 | 01 02} 


WAIT 
DAL anges > AT 
DIN eB @) ha 


‘SYNC’ IS MADE HIGH AS SOON AS A VALUD ADDRESS IS ON THE BUS (02) 

‘REPLY’ BEING LOW ON 03 CAUSES THE.‘OUTPUT’ INSTRUCTION TO BE EXECUTED REPEATEDLY 
‘DIN’ IS MADE HIGH AS SOON AS THE ADDRESS IS TAKEN OFF THE BUS (02) AS FUNCTION OF READ 
MICROINSTRUCTION 

‘REPLY’ AND ‘DIN’ MUST BE HIGH ON 03 IN ORDER FOR ‘INPUT’ INSTRUCTION TO TAKE PLACE 
UPON TERMINATION OF ‘INPUT’ INSTRUCTION, ‘SYNC’ AND ‘DIN’ ARE MADE LOW ON 02 


Oh Wye 


Figure 4-52. Read/Input Sequence 
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Read/Modify/Write Sequence (See Figure 4-53). The length of 
this sequence is variable. At least three instructions are 
required: _ 
READ Device Number 
INPUT Destination Register 
Microprogram can modify data 
OUTPUT Source Register 


A Read/Modify/Write operation is both a Read and Write in a 
Single Data Access operation. This provides for inputting 

data from an addressed unit, modifying it, and outputting the 
changed data to the same addressed unit. The Read/Modify/Write 
is initiated by a Read instruction which transfers a 16-bit 
address to the Data Access port. The address is present on the 
lines for one cycle and then data is placed on the lines by the 
addressed unit. Data is input to the processor registers by an 
Input Byte or Input Word instruction. The Data Access operation 
is not terminated as in the case of a normal Read, but continues 
for a subsequent output as specified by the Input instruction. 
This suspended period can be used to modify the data, if desired. 
An example might be an Increment Memory instruction. After 
modification, data is transferred from the processor registers 

to the Data Access port by an output byte or Output Word instruc- 
tion. The operation is terminated after the data has been on 


the line for a minimum of one cycle. 


NEXT INSTRUCTION 


R1W1 | 1B & MOD | 0 

01 | 041 01} 02 | 03} 04 | 01! 02 | 03 | 04 | 01] 02 | 03°} 04 | 01} 02] 03 | 04] 01 
WAIT } 

DAL 


ADDRESS DATA IN DATA OUT 


SYNC 


1 ‘INPUT & MOD’ WILL TURN ‘DIN’ OFF BUT WILL KEEP ‘SYNC’ ON 
2 ‘REPLY’ CAN BE MADE LOW AS SOON AS ‘SYNC’ AND ‘DIN’ ARE OFF 


Figure 4-53. Read/Modify/Write Sequence. 
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Interrupt Acknowledge Sequences. These two sequences provide 
the system designer with the ability to structure his own 
interrupt system. In addition to the normal READ or WRITE 


sequences, the processor will raise IACK at the specified time. 


The combination of IACK and a special reserved device number on 
DALOO-15 could, for example, order the device controller 
requesting attention to return its device number on the subse~ 


quent INPUT instruction. 


Figure 4-54 illustrates the operation of both the READ and WRITE 
Interrupt Acknowledge. 


o1 0? 0) 4 0) 0? 03 oO“ 01 6? 03 4 ot Ld 0.3 or dd 


walt papa 
1 Q ADDRESS STATUS CHT ar 
SYNC —_—-—-—-_ -_——Jr_-~—~CSsts—‘N 
we as = —— a 
Waitt Avil ~ 
R v eS ee ieee Se i — 
an ap «=e 4 
RA IB WAIT IB WAIT) in 
or 02 03 04 01 0? 03 o4 or @? 0.1 om“ a1 07 at m @1 0? 
WAIT / \ f \ 
Om =p eae aad —_ a-_ ==» 
TT ADDN a SD 
SYNC 
ae ean eee ewe «4, «oe oD 
DIN 
| Se mMmnPonmnP oa a ST 
1ACK 
(ACK TS TURNED ON FOR THE DURATION OF SYNC RY WA’ AND RA INST RIIC Fires 


Figure 4-54. Interrupt Acknowledge Sequence 


4-141 


4.4 CIRCUIT MODULE DESCRIPTION. 

This Section describes the operation of the individual circuit 
packages (DIPS) contained on the AM-100 two-board set. The 

CPU processing is handled by the set of five DIPS as described 
in paragraph 4.3. The control and interface modules are also 
described in the following paragraphs with logic and connection 


diagrams for each one. 
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4.4.1 FOUR-PHASE CLOCK GENERATOR (Board 2.U12). 

This device is a 4-phase clock generator using an external 
oscillator to initiate the phase-1 clock. By floating pins 9 
and 15, the chip also operates in a free-running mode where the 
phase-1 clock starts due to internal oscillation. Each of the 
other three clock phases follow in sequence provided the 

chip does not see another positive going edge from the oscilla- 
tor. Once phase-4 has returned to § volts, all four clock 
phases remain idle until the next positive going oscillator 
transition. If this transition occurs during one of the clock 
phases, the chip immediately tries to generate another phase-l. 


For stable operation, phase-4 should not overlap phase-1. 


Each clock phase width is independently controlled by an 
externally applied capacitor to ground. A 1% to 29 pf capacitor 
provides for an output clock phase width of 19@ ns. Logic and 


timing are shown in Figure 4=55. 


Pin Description 


Pin No. Symbol Function 

1 VBB -5 volts 

2 NC No connection 

3 $4 Out Phase-4 Output 

4 093 Out Phase-3 Output 

5 G2 Out Phase-2 Output 

6 91 Out Phase-1 Output 

7 VSS Ground 

8 VCC +5 to +15 volts 
9 Osc Input Oscillator Input 
10 VDD +12 volts 

11 @1 Cap Phase-1 Capacitor 
12 92 Cap Phase-2 Capacitor 
13 @3 Cap Phase-3 Capacitor 
14 @4 Cap Phase-4 Capacitor 
15 Gnd Ground 
16 NC No Connection 
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vcc 


Figure 4-55. 


Delay Delay Delay 


Oe | 

VOL ee eee ee PHASE-3 
N OF Sa 

VOL ee ee PHASE-4 
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- 


Four-phase Clock Logic and Timing 


e 
74-1 
Space or 
Gnd 


4.4.2 TRI-STATE 4-BIT D TYPE REGISTER (Board 1 U1, U9, U10). 
These four-bit registers contain D-type flip-flops with 
totem-pole TRI-STATE outputs, capable of driving highly 
Capacitive or low-impedance loads. 


Gated enable inputs are provided for controlling the entry of 
data into the flip-flops. When both data-enable inputs are 

low, data at the D inputs are loaded into their respective 
flip-flops on the next positive transition of the buffered clock 
input. Gate output control inputs are also provided. When 

both are low, the normal logic states of the four outputs are 
available for driving the loads or bus lines. The outputs are 
disabled independently from the level of the clock by a high 
logic level at either output-control input. The outputs then 
present a high impedance and neither load nor drive the bus 


line. Detailed operation and logic is shown in Figure 4-56. 


Connection Diagram Logic Diagram 


OATA EMAKE 
meuTs 


BATA meUTS 
Ver CLEAR 6 02 83 i] 62 6 


TT) 
oureur | # ° 
commnor | y 2 


oata (14 
0 


(w 
pata | 8! 18 41) 
EMAGLE | g2 ° 


| OATA ENABLE | ee 
evoca FA Nt fara : 


x 


oata (12) 
03 


cava itt 
When either M or N (or both) is (are) high the output is a 
Onabled to the high impedance state; however, sec.uential 
operation of the flip-flops is not affected. 


H = high level (steady state) . 
L = low level (steady state) 18 
: sa Clean | >O 
t © low-to-high level transition 
% = don't care (eny input including trensitions) 
Og = the level of O before the indiceted steedy state input 
conditions were esteblished 


Figure 4-56. Tri-State 4-Bit D Type Register Connections 
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4.4.3 HIGH SPEED HEX INVERTER (Board 1, U7). 
This device provides high speed low current interface logic. 
Logical inversion is provided with active pullups. See 


Figure 4-57 for logic and connections. 
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Figure 4-57. High Speed Hex Inverter Connections 
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4.4.4 TRI-STATE BUFFERS (Board 1, US, U8, U22, U24, U26; 
Board 2, U45, U46, U48). 

These devices provide six, two-input buffers in each package. 
One of the two inputs to each buffer is used as a control 
line to gate the output onto the high-impedance state, while 
the other input passes the data through the buffers. The 
Outputs are placed in the tri-state condition by applying a 
high logic level to the control pins. See Figure 4-58 for 
logic diagram and truth table. 


Logic and Connection Diagram Truth Table 


Figure 4-58. Tri-State Buffer Connections 
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4.4.5 HEX TRI-STATE BUFFERS (Board 2, U11, U47). 

These devices provide six, two-input buffers in each package. 
One of the two inputs to each buffer is used as a control line 
to gate the output onto the high-impedance state, while the 
other input passes the data through the buffer. The outputs 
are placed in the tri-state condition by applying a high logic 
level to the control pins. See Figure 4-59 for logic diagram 
and truth table. 


Logic and Connection Diagram Truth Table 


INPUTS OUTPUT 
fee ae 


La x i- 
L H L 
L L H 


= 
N 


Figure 4-59. Hex Tri-State Buffer Connections 
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4.4.6 EIGHT*LINE TO THREE“LINE ENCODER (Board 2, U29, U30)._ 
This device encodes eight data lines to three line (4-2-1) 

binary (octal). Cascading circuitry (enable input El and 

output EO) are provided to allow octal expansion without the 

need for external circuitry. Data inputs and outputs are 

active at the low logic level. See Figure 4-60 for logic diagram 
and truth table. 


(TOP VIEW) 
OUTPUTS 


Vcc ‘EO GS AO 


2 L.. 


positive logic: see function table 


~ 


FUNCTION TABLE 


eee (Cees OUTPUTS : 


= xiw 


L 
L 
L 
L 
L 
L 
L 
L 
L 


mex «MK KM MK K I KIO 
rerum eM MM KT KIO 
xr-Mxe EM KK XT KIN 
zririerxKxeu Kx 

zrrtrTrwe-x MK XT KJ a 
zTIrTrTrFTiru uM XI MI 
srr rTrTrTre;K Ir xie 
zrrreartTrtrTrereszxKj~w 
tzrrewrwrereererexzp.z 
22 CEE OO ez Ss 
zexerrertrrisieresxsxsd 
COP FCP POR LK em FZ S| 
zzrrwwrtrgrérwsreregréairrsd: 


Figure 4-60. Eight-Line to Three-Line Encoder Connections 
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4.4.7 DATA SELECTOR/MULTIPLEXER (Board 1, U16, U17, U18, U21). 
These Schottky clamped devices select a four-bit word from one 
of the two sources and route it to the four outputs as true 


data (no inversion). See Figure 4-61 for logic diagram and 
connections. | 


INPUTS INPUTS 
OurPul Outeut 
VCC stnuse “aa a6 4y COA IBY av 


G 4a 4b av 3A w 

$ 3yv 

F 1A ie tv rz y 28 av 

Seuect a ew, vo V2A 2a, 2% GRO 
OulPul 


inputs YUTPUT girs 


POSITIVE LOGIC: 
Low logic level at S selects A inputs. 
High logic level at S selects B inputs. 


14) 


- 

e 
e 
~ 
< 


ulele ay E 


(7) 
@ 


(9) 
e 


: 


(121 
° 


vv 
il 
yy 
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Figure 4-61. Data Selector/Multiplexer Connections 
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4.4.8 NAND TTL-TO-MOS DRIVER (Board 1, U2, U3). 

This device is a monolithic, integrated, dual TTL-TO-MOS driver . 
and interface circuit. It accepts standard TTL and DTL input 
Signals and provides high-current and high voltage output levels 
Suitable for driving MOS circuits. Specifically it can be used 
to drive address, control, and timing inputs for several types 
Of MOS RAMS. See Figure 4-62 for logic and connections. 


DUAL.-IN-LINE PACKAGE 
(TOP VIEW) 


Vceci t¥ 2¥v. Vcc2 


Vcc) Vcc2 


schematic (each driver) 
TO OTHER 
DRIVER 


INPUT A 


ENABLE E 


TO OTHER 
ORIVERS 


Figure 4-62. NAND TTL-TO-MOS Driver Connections 
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4.4.9 D POSITIVE-EDGE-TRIGGERED FLIP-FLOPS WITH PRESET AND 
CLEAR (Board 2, U6, U18, U19, U23, U31, U32, U34, U36). > 
See Figure 4-63 for logic diagram and truth table. 


Vor CLR2 ZL OPA az G2 
TRUTH TABLE 


INPUTS 


Figure 4-63. D Flip-Flop Connections 
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4.4.10 DUAL J-K NEGATIVE*“EDGE TRIGGERED FLIP-FLOPS WITH PRESET 
(Board 2, U20, U28, U40, U50, U51). See Figure 4-69 for logic 
diagram and truth table. 


Connection Diagram Truth Table 


TRUTH TABLE 


INPUTS OUTPUTS 


Figure 4-64. J-K Flip-Flop Connections 
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4.4.11 DUAL RETRIGGERABLE ONE=SHOTS WITH CLEAR (Board 2, U22). 
See Figure 4-65 for logic diagram and truth table. 


Rexy! 
Vv Con. Cexy? = G2 scum 62 Al TRUTH TABLE 


Coxnr2 Rex? eao 
Cans 


Notes: _J-L = one high-level pulse, LI = one low-level pulse. 
To use the internal timing resistor of 54121/74121, connect Ayyt to Vcc. 
An external timing capacitor may be connected between Cex 7 and Rex t/Cexy (positive). 
For accurate repeatable pulse widths, connect an external resistor between Re yx 7/Ce xy and Vcc with Rynz opencircuited. 
To obtain variable pulse widths, connect external variable resistance between Riqy or Rex 7/Ce x7 and Vcc. 


Figure 4-65. One Shot Connections 
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4.4.12 DUAL VOLTAGE CONTROLLED OSCILLATORS (Board 2, US). 

This device features two fully independent voltage-controlled 
oscillators (VCO's) in a single monolithic chip. The output 
frequency of each is established by a single external component, 
either a capacitor or a crystal, in combination with two voltage- 
sensitive inputs, one for frequency range and one for frequency 
control. An enable input is provided that can be used to start 
or stop the output pulses when it is low or high, respectively. 
The internal oscillator runs continuously, even while the output 
is disabled. A pulse synchronizer ensures that the first output 
pulse is neither clipped nor extended. Duty cycle of the output 
pulses is fixed at approximately 50 percent. See Figure 4-66 
for logic diagram and connections. 


The highly stable oscillator can be set to operate at any frequency 
between 0.12 Hz and 50 MHz typically. The output frequency can 
be approximated as follows: 


500 
fy ~ Cext 
where: F = output frequency in MHz 
Case = external capacitance in pF 


62 v2 
Vee ©)Vcc RANGE? Cyr? Cyxy2 -ENABLE OUTPUT GND 


2 1 RANGED Cony! Cexr! (GND 
Aco yrceerenecant 


61 Y1 
ENABLE OUTPUT 
FREQUENCY CONTROL 


Nete While the enedle input is low, the output ts enshled. While the enable input 1s high. 
the output is high. 


Figure 4-66. Dual Voltage Controlled Oscillator Connections 
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4.3.13 DECODER (Board 2, U7, U8, U42). 

These are Schottky-clamped circuits designed for memory~-decoding 
or data-routing applications requiring very short propagation 
delay times. This DIP decodes one of eight lines, based on the 
conditions at the three binary select inputs and the three 
enable inputs. See Figure 4-67 for logic diagram and truth 
table. 


Connection and Logic Diagram Truth Table 
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Figure 4-67. Decoder Connections 
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4.4.14 D FLIP-FLOPS WITH CLEAR (Board 1, U13, U14, U25; 


Board 2, U10). 


These positive-edge-triggered flip-flops utilize TTL circuitry 


to implement D-type flip-flop logic. 


Information at the D 


inputs meeting the setup time requirements is transferred to 


the Q-outputs on the positive-going edge of the clock pulse. 


Clock triggering occurs at a particular voltage level and is 


not directly related to the transition time of the positive- 


going pulse. When the clock input is at either the high or 


low level, the D input signal has no effect at the output. 


see Figure 4-68 for logic diagram and truth table. 


Logic Diagram 
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Figure 4-68. 


Connection Diagram 


Truth Table 


CLEAR CLOCK D 
x x 
t H 
t L 
L x 


H = High Level (steady state) 

L = Low Level (steady state) 

X = Don't Care 

t = Transition from low to high level 


Qo = The level of Q before the indicated steedy-state input 
conditions were established. 
t = 175, S175, and S175 only 


° 
Q} 


Poe rer 
f'xrree 


D Flip-Flop Connections 
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44.15 TRI-STATE OCTAL BUFFERS (Board 1, U6, U1ll, U19, U27). 
This device provides six, two-input buffers in each package. 
One of the two inputs is used as a control line to gate the 
output into a high impedance state, while the other passes 
the data through the buffer. The outputs are placed in the 
tri-state condition by applying a high logic level to the 
control pins. See Figure 4-69 for logic diagram and truth 
table. 


Logic Diagram Truth Table 


Figure 4-69. Tri-State Octal Buffer Connections 
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SECTION 5 
MAINTENANCE AND TROUBLESHOOTING 


5.0 INTRODUCTION. 
The AM-100 circuit board performs to full capability with a 
minimum of maintenance. This Section describes maintenance 


procedures and procedures for handling warranty returns. 


5.1 CIRCUIT BOARD CHECKOUT. 

The AM-100 circuit board was fully tested before it left Alpha 
Microsystems and will operate satisfactorily in your system 

if the hardware and software requirements of Sections Two and 
Three of this manual are met. Should a problem arise after 
the circuit card has been in operation, perform the following 
preliminary checks to identify and locate the fault. 


1. Check all cabling for proper seating of connectors. 


2. Check the circuit board for proper seating in the 
slot. 


3. Check all power connections for correct voltages. 


4. Check all jumper options to ensure correctness for 
your application. 


5. Verify that the fault is in the AM-100 and not 
either in the system or in the peripherals. This 
can best be accomplished with substitution of a 
known good circuit board if available. 


5.2 WARRANTY PROCEDURES. 

This circuit board is covered by warranty issued by Alpha 
Microsystems, Irvine, California. Complete details of the 
warranty are included with the circuit board. Should a 
problem arise with this circuit board, call your dealer or 
the Alpha Micro International Support Services Administrator 


for information. 
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